/*!******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app/[locale]/layout.tsx","import":"Space_Grotesk","arguments":[{"subsets":["latin"],"variable":"--font-display","weight":["400","500","600","700"]}],"variableName":"displayFont"} ***!
  \******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* vietnamese */
@font-face {
  font-family: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/e1aab0933260df4d-s.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/b7387a63dd068245-s.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/36966cca54120369-s.p.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/e1aab0933260df4d-s.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/b7387a63dd068245-s.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/36966cca54120369-s.p.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/e1aab0933260df4d-s.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/b7387a63dd068245-s.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/36966cca54120369-s.p.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/e1aab0933260df4d-s.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/b7387a63dd068245-s.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: '__Space_Grotesk_49a339';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/36966cca54120369-s.p.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;
}@font-face {font-family: '__Space_Grotesk_Fallback_49a339';src: local("Arial");ascent-override: 89.71%;descent-override: 26.62%;line-gap-override: 0.00%;size-adjust: 109.69%
}.__className_49a339 {font-family: '__Space_Grotesk_49a339', '__Space_Grotesk_Fallback_49a339';font-style: normal
}.__variable_49a339 {--font-display: '__Space_Grotesk_49a339', '__Space_Grotesk_Fallback_49a339'
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app/[locale]/layout.tsx","import":"Fraunces","arguments":[{"subsets":["latin"],"variable":"--font-body","weight":["400","500","600","700"]}],"variableName":"bodyFont"} ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* vietnamese */
@font-face {
  font-family: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/fb526027db1fc1ae-s.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/4da3161b738b07dd-s.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/af4bf8399d1aacdf-s.p.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/fb526027db1fc1ae-s.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/4da3161b738b07dd-s.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/af4bf8399d1aacdf-s.p.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/fb526027db1fc1ae-s.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/4da3161b738b07dd-s.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/af4bf8399d1aacdf-s.p.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/fb526027db1fc1ae-s.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/4da3161b738b07dd-s.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: '__Fraunces_acf54a';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/af4bf8399d1aacdf-s.p.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;
}@font-face {font-family: '__Fraunces_Fallback_acf54a';src: local("Times New Roman");ascent-override: 84.71%;descent-override: 22.09%;line-gap-override: 0.00%;size-adjust: 115.45%
}.__className_acf54a {font-family: '__Fraunces_acf54a', '__Fraunces_Fallback_acf54a';font-style: normal
}.__variable_acf54a {--font-body: '__Fraunces_acf54a', '__Fraunces_Fallback_acf54a'
}

/*!************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app/[locale]/layout.tsx","import":"IBM_Plex_Sans_Thai","arguments":[{"subsets":["thai","latin"],"variable":"--font-thai","weight":["400","500","600","700"]}],"variableName":"thaiFont"} ***!
  \************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/db9bfcd87f1d73a3-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* thai */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/4e2312c98e240c05-s.p.woff2) format('woff2');
  unicode-range: U+02D7, U+0303, U+0331, U+0E01-0E5B, U+200C-200D, U+25CC;
}
/* latin-ext */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/feed52454563c595-s.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: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/f83e5507ec3854fa-s.p.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: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/8934311971e59087-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* thai */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/bfdf244a9384e8b2-s.p.woff2) format('woff2');
  unicode-range: U+02D7, U+0303, U+0331, U+0E01-0E5B, U+200C-200D, U+25CC;
}
/* latin-ext */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/b10e9fa1144bb4fb-s.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: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/d13ab8ed065835e4-s.p.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: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/d8c0f620f258dcc1-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* thai */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/5fcb63deed33aab6-s.p.woff2) format('woff2');
  unicode-range: U+02D7, U+0303, U+0331, U+0E01-0E5B, U+200C-200D, U+25CC;
}
/* latin-ext */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/e595057e1ab84c19-s.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: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/861fabf8a4ffc042-s.p.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: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/2b32cc5cb75c7a84-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* thai */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/0d4277ce62acaedf-s.p.woff2) format('woff2');
  unicode-range: U+02D7, U+0303, U+0331, U+0E01-0E5B, U+200C-200D, U+25CC;
}
/* latin-ext */
@font-face {
  font-family: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/942c4903ae74b0f3-s.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: '__IBM_Plex_Sans_Thai_218bf9';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/66c5464579bf95d1-s.p.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;
}@font-face {font-family: '__IBM_Plex_Sans_Thai_Fallback_218bf9';src: local("Arial");ascent-override: 110.31%;descent-override: 52.78%;line-gap-override: 0.00%;size-adjust: 101.17%
}.__className_218bf9 {font-family: '__IBM_Plex_Sans_Thai_218bf9', '__IBM_Plex_Sans_Thai_Fallback_218bf9';font-style: normal
}.__variable_218bf9 {--font-thai: '__IBM_Plex_Sans_Thai_218bf9', '__IBM_Plex_Sans_Thai_Fallback_218bf9'
}

/*!*************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[12].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[12].use[3]!./app/globals.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************/
:root {
  --ink: #10131a;
  --ink-soft: #2d3340;
  --sand: #f6f1e9;
  --panel: rgba(255, 255, 255, 0.86);
  --panel-strong: rgba(255, 255, 255, 0.96);
  --accent: #ff6f3c;
  --accent-strong: #e64511;
  --sky: #9ec7ff;
  --mint: #d1f5e2;
  --stroke: rgba(16, 19, 26, 0.08);
  --shadow: 0 18px 40px rgba(16, 19, 26, 0.08);
  --radius: 18px;
}

html[lang="th"] {
  --font-body: var(--font-thai);
  --font-display: var(--font-thai);
}

* {
  box-sizing: border-box;
}

html,
body {
  padding: 0;
  margin: 0;
  min-height: 100%;
  color: var(--ink);
  background: linear-gradient(135deg, #fff6eb 0%, #eef3ff 45%, #f7f0ff 100%);
  font-family: var(--font-body), "Segoe UI", sans-serif;
}

body::before,
body::after {
  content: "";
  position: fixed;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  filter: blur(0px);
  opacity: 0.5;
  z-index: -1;
}

body::before {
  top: -120px;
  right: -140px;
  background: radial-gradient(circle at 30% 30%, #ffd8c2 0%, transparent 70%);
}

body::after {
  bottom: -160px;
  left: -120px;
  background: radial-gradient(circle at 40% 40%, #cde9ff 0%, transparent 72%);
}

a {
  color: inherit;
  text-decoration: none;
}

main {
  max-width: 1200px;
  margin: 0 auto;
  padding: 32px 24px 64px;
}

.shell {
  min-height: 100vh;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 20px 32px;
  background: var(--panel);
  -webkit-backdrop-filter: blur(12px);
          backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--stroke);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 10;
}

/* Transparent topbar for landing/hero overlay */
.topbar-transparent {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: transparent;
  -webkit-backdrop-filter: none;
          backdrop-filter: none;
  border-bottom: none;
  color: #fff;
  z-index: 100;
}

.topbar-transparent .brand,
.topbar-transparent .nav a,
.topbar-transparent .login-link {
  color: rgba(255, 255, 255, 0.9);
  transition: color 0.2s ease;
}

.topbar-transparent .brand:hover,
.topbar-transparent .nav a:hover,
.topbar-transparent .login-link:hover {
  color: #fbbf24;
}

.topbar-transparent .profile-link svg {
  color: rgba(255, 255, 255, 0.9);
}

/* Shell variant for landing page (no main padding) */
.shell-landing main {
  max-width: none;
  padding: 0;
  margin: 0;
}

.brand-link {
  text-decoration: none;
  color: inherit;
}

.brand {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 24px;
  letter-spacing: 0.02em;
}

.admin-home-link {
  font-size: 13px;
  color: var(--accent);
  text-decoration: none;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(255, 111, 60, 0.1);
  transition: background 0.2s ease;
}

.admin-home-link:hover {
  background: rgba(255, 111, 60, 0.2);
}

.profile-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  color: var(--ink-soft);
  text-decoration: none;
  transition: all 0.2s ease;
}

.profile-link:hover {
  color: var(--accent);
  background: rgba(255, 111, 60, 0.1);
}

.profile-link svg {
  flex-shrink: 0;
}

.nav {
  display: flex;
  gap: 16px;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.nav a {
  padding: 6px 10px;
  border-radius: 999px;
  transition: all 0.2s ease;
}

.nav a:hover {
  background: var(--mint);
}

.subtle {
  color: var(--ink-soft);
  font-size: 13px;
}

.hero {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  grid-gap: 28px;
  gap: 28px;
  align-items: center;
  background: var(--panel-strong);
  border-radius: var(--radius);
  padding: 40px;
  box-shadow: var(--shadow);
  animation: fadeUp 0.6s ease;
}

.hero h1 {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: clamp(32px, 4vw, 46px);
  margin: 0 0 12px;
}

.hero p {
  margin: 0 0 22px;
  color: var(--ink-soft);
  font-size: 16px;
}

.hero .cta-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.button {
  border: none;
  border-radius: 999px;
  padding: 10px 18px;
  font-weight: 600;
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  transition: transform 0.2s ease, background 0.2s ease;
}

.button:hover {
  background: var(--accent-strong);
  transform: translateY(-1px);
}

.button.secondary {
  background: #fff;
  color: var(--ink);
  border: 1px solid var(--stroke);
}

.panel {
  background: var(--panel-strong);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: var(--shadow);
  border: 1px solid var(--stroke);
}

.panel+.panel {
  margin-top: 18px;
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.section-header h2 {
  margin: 0;
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 28px;
}

.table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.table th,
.table td {
  text-align: left;
  padding: 12px 10px;
  border-bottom: 1px solid var(--stroke);
}

.table th {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
}

.table tr:hover {
  background: rgba(255, 255, 255, 0.6);
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--mint);
  font-size: 12px;
  font-weight: 600;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 13px;
  color: var(--ink-soft);
}

.field input,
.field select,
.field textarea {
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 14px;
  font-family: inherit;
  color: var(--ink);
  background: #fff;
}

.field textarea {
  min-height: 96px;
  resize: vertical;
}

.meta-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  color: var(--ink-soft);
}

.notice {
  padding: 12px 14px;
  border-radius: 12px;
  background: #fff6f1;
  border: 1px solid #ffd7c4;
  color: #993411;
  font-size: 13px;
}

.empty {
  padding: 24px;
  text-align: center;
  color: var(--ink-soft);
}

.stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  grid-gap: 12px;
  gap: 12px;
  margin-top: 18px;
}

.stat-card {
  background: rgba(255, 255, 255, 0.75);
  border-radius: 14px;
  border: 1px solid var(--stroke);
  padding: 16px;
}

.stat-value {
  font-size: 24px;
  font-weight: 600;
}

.stat-label {
  margin-top: 6px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
}

.admin-grid {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.list-compact {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  font-size: 14px;
}

.list-compact li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px dashed var(--stroke);
  padding-bottom: 8px;
  gap: 12px;
}

.list-compact li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 720px) {
  .topbar {
    flex-direction: row;
    align-items: center;
    padding: 12px 16px;
  }

  /* Hide secondary nav links on mobile to prevent crowding */
  .topbar .nav {
    display: none;
  }

  main {
    padding: 24px 16px 48px;
  }

  /* Adjust hero subtitle mobile spacing */
  .hero-subtitle-cinematic {
    font-size: 16px;
    margin-bottom: 30px;
  }
}

/* ============================================
   Vintage Lens Detail Page Styles
   ============================================ */

:root {
  --gold: #ca8a04;
  --gold-soft: #fef3c7;
  --cream: #fafaf9;
  --stone: #1c1917;
  --stone-soft: #44403c;
  --warm-border: #d6d3d1;
}

/* Breadcrumb */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--ink-soft);
  margin-bottom: 24px;
}

.breadcrumb a {
  color: var(--ink-soft);
  transition: color 0.2s ease;
}

.breadcrumb a:hover {
  color: var(--accent);
}

.breadcrumb-sep {
  opacity: 0.4;
}

.breadcrumb-current {
  color: var(--ink);
  font-weight: 500;
}

/* Main Grid Layout */
.lens-detail {
  animation: fadeUp 0.5s ease;
}

.lens-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 48px;
  gap: 48px;
  margin-bottom: 48px;
}

/* Image Gallery */
.lens-gallery {
  position: -webkit-sticky;
  position: sticky;
  top: 100px;
  align-self: start;
}

.lens-main-image {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--panel-strong);
  box-shadow: var(--shadow);
  cursor: zoom-in;
  border: 1px solid var(--stroke);
}

.lens-main-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.lens-main-image:hover img {
  transform: scale(1.02);
}

.lens-main-image.zoomed {
  cursor: zoom-out;
  background-size: 200%;
  background-repeat: no-repeat;
}

.lens-main-image.zoomed img {
  opacity: 0;
}

.zoom-hint {
  position: absolute;
  bottom: 16px;
  right: 16px;
  padding: 6px 12px;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  font-size: 12px;
  border-radius: 999px;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.lens-main-image:hover .zoom-hint {
  opacity: 1;
}

.condition-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  padding: 8px 16px;
  background: var(--gold);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: 999px;
  text-transform: uppercase;
}

.lens-thumbnails {
  display: flex;
  gap: 12px;
  margin-top: 16px;
  overflow-x: auto;
  padding-bottom: 8px;
}

.thumbnail {
  position: relative;
  flex-shrink: 0;
  width: 72px;
  height: 72px;
  border-radius: 12px;
  overflow: hidden;
  border: 2px solid transparent;
  background: var(--panel-strong);
  cursor: pointer;
  transition: all 0.2s ease;
}

.thumbnail:hover {
  border-color: var(--stroke);
}

.thumbnail.active {
  border-color: var(--accent);
}

.thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.primary-badge {
  position: absolute;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%);
  padding: 2px 6px;
  background: var(--accent);
  color: #fff;
  font-size: 9px;
  font-weight: 600;
  border-radius: 4px;
  text-transform: uppercase;
}

/* Product Info */
.lens-info {
  padding-top: 8px;
}

.lens-header {
  margin-bottom: 24px;
}

.lens-brand {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 8px;
}

.lens-name {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 500;
  line-height: 1.2;
  margin: 0 0 8px;
  color: var(--ink);
}

.lens-model {
  font-size: 14px;
  color: var(--ink-soft);
}

/* Price Section */
.lens-price-section {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--stroke);
}

.lens-price {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 36px;
  font-weight: 600;
  color: var(--ink);
}

.lens-availability .available {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: var(--mint);
  color: #166534;
  font-size: 13px;
  font-weight: 600;
  border-radius: 999px;
}

.lens-availability .unavailable {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: #fee2e2;
  color: #991b1b;
  font-size: 13px;
  font-weight: 600;
  border-radius: 999px;
}

/* Quick Specs */
.lens-quick-specs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 24px;
}

.spec-pill {
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  border: 1px solid var(--stroke);
  background: #fff;
}

.spec-pill.mount {
  background: var(--gold-soft);
  border-color: var(--gold);
  color: #92400e;
}

.spec-pill.focal {
  background: #dbeafe;
  border-color: #3b82f6;
  color: #1e40af;
}

.spec-pill.aperture {
  background: #f3e8ff;
  border-color: #a855f7;
  color: #6b21a8;
}

/* Action Buttons */
.lens-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 24px;
}

.button.primary {
  background: var(--accent);
  color: #fff;
}

.button.primary:hover {
  background: var(--accent-strong);
}

.button.large {
  padding: 16px 28px;
  font-size: 15px;
}

.button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none !important;
}

.serial-number {
  font-size: 13px;
  color: var(--ink-soft);
  font-family: monospace;
  padding: 12px 16px;
  background: #f5f5f4;
  border-radius: 8px;
}

/* Detail Sections */
.lens-detail-sections {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.detail-section {
  background: var(--panel-strong);
  border-radius: var(--radius);
  padding: 32px;
  box-shadow: var(--shadow);
  border: 1px solid var(--stroke);
}

.section-title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 24px;
  font-weight: 500;
  margin: 0 0 24px;
  color: var(--ink);
}

.section-title svg {
  color: var(--gold);
}

/* Condition Section */
.condition-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 20px;
  gap: 20px;
  margin-bottom: 24px;
}

.condition-card {
  padding: 20px;
  background: #fafaf9;
  border-radius: 12px;
  border: 1px solid var(--stroke);
}

.condition-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
  margin-bottom: 12px;
  font-weight: 600;
}

.condition-meter {
  height: 8px;
  background: #e7e5e4;
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 12px;
}

.meter-fill {
  height: 100%;
  border-radius: 999px;
  transition: width 0.5s ease;
}

.meter-fill.optical {
  background: linear-gradient(90deg, #22c55e, #16a34a);
}

.meter-fill.mechanical {
  background: linear-gradient(90deg, #3b82f6, #2563eb);
}

.meter-fill.cosmetic {
  background: linear-gradient(90deg, #f59e0b, #d97706);
}

.condition-desc {
  font-size: 13px;
  color: var(--ink-soft);
}

.condition-notes,
.accessories {
  padding: 20px;
  background: #fafaf9;
  border-radius: 12px;
  margin-top: 16px;
}

.condition-notes h3,
.accessories h3 {
  font-size: 14px;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--ink);
}

.condition-notes p,
.accessories p {
  margin: 0;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.6;
}

/* Adapter Section */
.adapter-intro {
  color: var(--ink-soft);
  margin: 0 0 24px;
  font-size: 15px;
  line-height: 1.6;
}

.camera-selector {
  margin-bottom: 24px;
}

.camera-selector label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 8px;
}

.camera-selector select {
  width: 100%;
  max-width: 400px;
  padding: 14px 16px;
  border: 1px solid var(--stroke);
  border-radius: 12px;
  font-size: 15px;
  font-family: inherit;
  color: var(--ink);
  background: #fff;
  cursor: pointer;
}

.camera-selector select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255, 111, 60, 0.15);
}

.adapter-results h3 {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 16px;
  color: var(--ink);
}

.adapter-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.adapter-card {
  padding: 20px;
  background: #fff;
  border-radius: 12px;
  border: 1px solid var(--stroke);
  transition: all 0.2s ease;
}

.adapter-card:hover {
  border-color: var(--gold);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.adapter-card.premium {
  border-color: var(--gold);
  background: linear-gradient(135deg, #fffbeb 0%, #fff 100%);
}

.adapter-quality {
  display: inline-block;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: 999px;
  margin-bottom: 12px;
}

.adapter-card.premium .adapter-quality {
  background: var(--gold);
  color: #fff;
}

.adapter-card.standard .adapter-quality {
  background: #dbeafe;
  color: #1e40af;
}

.adapter-card.budget .adapter-quality {
  background: #e7e5e4;
  color: var(--ink-soft);
}

.adapter-name {
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 4px;
}

.adapter-brand {
  font-size: 13px;
  color: var(--ink-soft);
  margin-bottom: 12px;
}

.adapter-features {
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
}

.adapter-features li {
  font-size: 13px;
  color: var(--ink-soft);
  padding: 4px 0;
  padding-left: 20px;
  position: relative;
}

.adapter-features li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 6px;
  height: 6px;
  background: var(--mint);
  border-radius: 50%;
}

.adapter-price {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
}

.no-adapters {
  padding: 24px;
  background: #fafaf9;
  border-radius: 12px;
  text-align: center;
}

.no-adapters p {
  margin: 0;
  color: var(--ink-soft);
  font-size: 14px;
}

/* Optical Characteristics */
.optical-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 16px;
  gap: 16px;
}

.optical-item {
  padding: 16px 20px;
  background: #fafaf9;
  border-radius: 12px;
  border: 1px solid var(--stroke);
}

.optical-label {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
  margin-bottom: 6px;
  font-weight: 600;
}

.optical-value {
  display: block;
  font-size: 14px;
  color: var(--ink);
  font-weight: 500;
}

/* Heritage Section */
.heritage-content {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.production-years {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  background: var(--gold-soft);
  border-radius: 999px;
  align-self: flex-start;
}

.years-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #92400e;
  font-weight: 600;
}

.years-value {
  font-size: 14px;
  font-weight: 600;
  color: #78350f;
}

.heritage-text h3 {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--ink);
}

.heritage-text p {
  margin: 0;
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 1.7;
}

.notable-features h3,
.famous-users h3 {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 12px;
  color: var(--ink);
}

.notable-features ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.notable-features li {
  padding: 8px 0;
  padding-left: 24px;
  position: relative;
  font-size: 14px;
  color: var(--ink-soft);
  border-bottom: 1px solid var(--stroke);
}

.notable-features li:last-child {
  border-bottom: none;
}

.notable-features li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 14px;
  width: 8px;
  height: 8px;
  background: var(--gold);
  border-radius: 2px;
  transform: rotate(45deg);
}

.users-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.user-tag {
  padding: 6px 14px;
  background: #f5f5f4;
  border-radius: 999px;
  font-size: 13px;
  color: var(--ink-soft);
}

/* Sample Photos */
.samples-intro {
  color: var(--ink-soft);
  margin: 0 0 24px;
  font-size: 15px;
}

.samples-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  grid-gap: 20px;
  gap: 20px;
}

.sample-card {
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--stroke);
  transition: all 0.2s ease;
}

.sample-card:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  transform: translateY(-2px);
}

.sample-image {
  aspect-ratio: 4/3;
  overflow: hidden;
}

.sample-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.sample-card:hover .sample-image img {
  transform: scale(1.05);
}

.sample-meta {
  padding: 16px;
}

.sample-camera {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 4px;
}

.sample-settings {
  font-size: 12px;
  color: var(--gold);
  font-family: monospace;
  margin-bottom: 8px;
}

.sample-desc {
  font-size: 13px;
  color: var(--ink-soft);
}

/* Purchase Terms Accordion */
.terms-accordion {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.term-item {
  border: 1px solid var(--stroke);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}

.term-header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: background 0.2s ease;
}

.term-header:hover {
  background: #fafaf9;
}

.term-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
}

.term-chevron {
  color: var(--ink-soft);
  transition: transform 0.2s ease;
}

.term-item.expanded .term-chevron {
  transform: rotate(180deg);
}

.term-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.term-item.expanded .term-content {
  max-height: 500px;
}

.term-content p {
  padding: 0 20px 20px;
  margin: 0;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.7;
}

/* Special Section */
.special-content p {
  margin: 0;
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 1.7;
  font-style: italic;
}

/* Sticky Bottom Bar (Mobile) */
.sticky-bottom-bar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 16px 20px;
  background: var(--panel-strong);
  -webkit-backdrop-filter: blur(12px);
          backdrop-filter: blur(12px);
  border-top: 1px solid var(--stroke);
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.1);
  z-index: 100;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.sticky-price {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 24px;
  font-weight: 600;
}

/* Responsive */
@media (max-width: 1024px) {
  .lens-detail-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .lens-gallery {
    position: relative;
    top: 0;
  }

  .condition-grid {
    grid-template-columns: 1fr;
  }

  .optical-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 720px) {
  .lens-detail-grid {
    gap: 24px;
  }

  .detail-section {
    padding: 24px 20px;
  }

  .lens-price {
    font-size: 28px;
  }

  .optical-grid {
    grid-template-columns: 1fr;
  }

  .adapter-cards {
    grid-template-columns: 1fr;
  }

  .samples-grid {
    grid-template-columns: 1fr;
  }

  .sticky-bottom-bar {
    display: flex;
  }

  .lens-actions {
    display: none;
  }

  .lens-detail {
    padding-bottom: 100px;
  }
}

/* ============================================
   Checkout Flow Styles
   ============================================ */

.checkout-page {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.checkout-header h1 {
  margin: 0 0 8px;
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: clamp(28px, 4vw, 40px);
}

.checkout-header p {
  margin: 0;
  color: var(--ink-soft);
  font-size: 15px;
}

.checkout-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  grid-gap: 24px;
  gap: 24px;
}

.checkout-title {
  margin: 0 0 16px;
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
}

.checkout-summary.panel,
.shipping-form.panel,
.payment-qr.panel,
.slip-upload.panel,
.confirmation-card.panel {
  background: var(--panel-strong);
}

.checkout-items {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  margin-bottom: 20px;
}

.checkout-item {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--stroke);
}

.checkout-item-name {
  font-weight: 600;
}

.checkout-item-type {
  font-size: 12px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.checkout-item-price {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  font-weight: 600;
}

.price-original {
  font-size: 12px;
  color: var(--ink-soft);
  text-decoration: line-through;
}

.checkout-totals {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  border-top: 1px solid var(--stroke);
  padding-top: 16px;
}

.checkout-total-row {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
  color: var(--ink-soft);
}

.checkout-total-row.total {
  font-size: 16px;
  color: var(--ink);
  font-weight: 700;
}

.checkout-total-row.discount {
  color: #b45309;
}

.shipping-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 13px;
  color: var(--ink-soft);
}

.shipping-form input,
.shipping-form textarea,
.shipping-form select {
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding: 12px 14px;
  font-size: 14px;
  font-family: inherit;
  color: var(--ink);
  background: #fff;
}

.shipping-form select {
  cursor: pointer;
}

.shipping-form textarea {
  resize: vertical;
}

.shipping-form .form-actions {
  margin-top: 16px;
}

.payment-qr-grid {
  display: grid;
  grid-template-columns: minmax(160px, 200px) 1fr;
  grid-gap: 20px;
  gap: 20px;
  align-items: center;
}

.payment-steps.panel {
  background: linear-gradient(135deg, #fff7ed 0%, #fff 65%);
}

.payment-steps-header {
  margin-bottom: 20px;
}

.payment-steps-header h2 {
  margin: 6px 0 8px;
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 22px;
}

.payment-steps-header p {
  margin: 0;
  color: var(--ink-soft);
  font-size: 14px;
}

.step-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--gold-soft);
  color: #92400e;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
}

.payment-steps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.payment-step-card {
  padding: 16px;
  border-radius: 14px;
  border: 1px solid var(--warm-border);
  background: #fff;
  box-shadow: 0 10px 20px rgba(16, 19, 26, 0.06);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  animation: fadeUp 0.4s ease both;
}

.payment-step-card:nth-child(2) {
  animation-delay: 0.05s;
}

.payment-step-card:nth-child(3) {
  animation-delay: 0.1s;
}

.payment-step-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(16, 19, 26, 0.12);
}

.payment-step-card h3 {
  margin: 10px 0 6px;
  font-size: 16px;
}

.payment-step-card p {
  margin: 0;
  color: var(--ink-soft);
  font-size: 13px;
  line-height: 1.5;
}

.step-badge {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: var(--accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
}

.qr-box {
  border-radius: 16px;
  border: 1px dashed var(--warm-border);
  background: #fff;
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 180px;
}

.qr-box img {
  width: 100%;
  height: auto;
}

.qr-placeholder {
  text-align: center;
  color: var(--ink-soft);
  font-size: 12px;
}

.qr-placeholder-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: var(--gold-soft);
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  margin-bottom: 8px;
}

.qr-details {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.qr-amount {
  font-size: 24px;
  font-weight: 600;
  color: var(--ink);
}

.qr-number {
  font-size: 18px;
  font-weight: 600;
}

.qr-name {
  color: var(--ink-soft);
  font-size: 13px;
}

.qr-note {
  margin: 0;
  font-size: 13px;
  color: var(--ink-soft);
}

.slip-hint {
  margin: 0 0 16px;
  font-size: 14px;
  color: var(--ink-soft);
}

.slip-input {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.slip-input input {
  flex: 1 1 240px;
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding: 12px 14px;
  font-size: 14px;
}

.checkout-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.confirmation-card {
  text-align: center;
}

.confirmation-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--mint);
  color: #166534;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  margin: 0 auto 16px;
}

.confirmation-note {
  margin: 12px 0 24px;
  color: var(--ink-soft);
}

.confirmation-shipping {
  text-align: left;
  margin: 24px auto;
  max-width: 420px;
  background: #fff;
  border-radius: 14px;
  padding: 16px;
  border: 1px solid var(--stroke);
}

.confirmation-shipping h3 {
  margin: 0 0 8px;
  font-size: 14px;
}

.button.small {
  padding: 6px 12px;
  font-size: 12px;
}

@media (max-width: 720px) {
  .payment-qr-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   Shareable Page Styles
   ============================================ */

.share-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.share-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 32px;
  background: var(--panel-strong);
  -webkit-backdrop-filter: blur(12px);
          backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--stroke);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 50;
}

.share-logo {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
}

.share-nav {
  display: flex;
  gap: 24px;
}

.share-nav a {
  font-size: 14px;
  color: var(--ink-soft);
  text-decoration: none;
  transition: color 0.2s ease;
}

.share-nav a:hover {
  color: var(--accent);
}

.share-main {
  flex: 1 1;
  max-width: 1200px;
  margin: 0 auto;
  padding: 32px 24px 64px;
  width: 100%;
}

/* AI Recommendation Banner */
.ai-recommendation-banner {
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  border-bottom: 1px solid #fcd34d;
}

.ai-banner-content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: #92400e;
}

.ai-banner-content svg {
  flex-shrink: 0;
  color: #d97706;
}

/* Loading State */
.share-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 120px 24px;
  text-align: center;
}

.loading-spinner {
  width: 48px;
  height: 48px;
  border: 3px solid var(--stroke);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-bottom: 16px;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.share-loading p {
  color: var(--ink-soft);
  font-size: 15px;
}

/* Error State */
.share-error {
  text-align: center;
  padding: 80px 24px;
}

.share-error h1 {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 32px;
  margin: 0 0 12px;
  color: var(--ink);
}

.share-error p {
  color: var(--ink-soft);
  font-size: 15px;
  margin: 0 0 24px;
}

/* Footer */
.share-footer {
  background: var(--ink);
  color: #fff;
  padding: 48px 24px;
  margin-top: auto;
}

.footer-content {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 48px;
}

.footer-logo {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 24px;
  font-weight: 600;
  display: block;
  margin-bottom: 8px;
}

.footer-brand p {
  color: rgba(255, 255, 255, 0.6);
  font-size: 14px;
  margin: 0;
}

.footer-links {
  display: flex;
  gap: 24px;
}

.footer-links a {
  color: rgba(255, 255, 255, 0.8);
  font-size: 14px;
  text-decoration: none;
  transition: color 0.2s ease;
}

.footer-links a:hover {
  color: #fff;
}

@media (max-width: 720px) {
  .share-header {
    padding: 12px 16px;
  }

  .share-nav {
    display: none;
  }

  .share-main {
    padding: 24px 16px 48px;
  }

  .ai-banner-content {
    padding: 10px 16px;
    font-size: 13px;
  }

  .footer-content {
    flex-direction: column;
    gap: 24px;
    text-align: center;
  }

  .footer-links {
    flex-wrap: wrap;
    justify-content: center;
  }
}

/* Adapter Compatibility & Stock Styles */
.compatibility-message {
  padding: 16px 20px;
  border-radius: 12px;
  margin-bottom: 24px;
  font-weight: 500;
  line-height: 1.6;
  font-size: 14px;
}

.compatibility-message.compatible {
  background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
  color: #065f46;
  border: 2px solid #10b981;
}

.compatibility-message.incompatible {
  background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
  color: #991b1b;
  border: 2px solid #ef4444;
}

.adapter-card {
  position: relative;
}

.adapter-card.out-of-stock {
  opacity: 0.7;
  border-color: #d1d5db;
  background: #f9fafb;
}

.stock-badge {
  position: absolute;
  top: 16px;
  right: 16px;
  padding: 6px 14px;
  border-radius: 16px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.3px;
}

.stock-badge.in-stock {
  background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
  color: #065f46;
  border: 1px solid #10b981;
}

.stock-badge.out-of-stock {
  background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
  color: #991b1b;
  border: 1px solid #ef4444;
}

.marketplace-keywords {
  margin-top: 16px;
  padding: 14px;
  background: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);
  border-radius: 8px;
  border: 1px solid #d1d5db;
}

.marketplace-keywords strong {
  display: block;
  margin-bottom: 10px;
  color: #374151;
  font-size: 14px;
}

.marketplace-links {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}

.marketplace-links a {
  flex: 1 1;
  padding: 10px 16px;
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  color: white;
  border-radius: 8px;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  transition: all 0.2s;
  border: 1px solid #1d4ed8;
}

.marketplace-links a:hover {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(37, 99, 235, 0.3);
}

.loading {
  text-align: center;
  padding: 40px;
  color: #6b7280;
  font-size: 16px;
}

.no-adapters {
  padding: 32px;
  text-align: center;
  background: #f9fafb;
  border-radius: 12px;
  border: 1px dashed #d1d5db;
}

.no-adapters p {
  margin: 0;
  color: #6b7280;
  font-size: 14px;
}

/* ============================================
   Landing Page Styles
   ============================================ */

.landing-page {
  min-height: 100vh;
}

/* Hero Section */
.landing-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 48px;
  gap: 48px;
  align-items: center;
  min-height: calc(100vh - 200px);
  padding: 48px 0;
}

.hero-content {
  max-width: 540px;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  color: #92400e;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 999px;
  margin-bottom: 24px;
}

.hero-title {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 700;
  line-height: 1.1;
  margin: 0 0 16px;
  color: var(--ink);
}

.hero-subtitle {
  font-size: 18px;
  color: var(--ink-soft);
  margin: 0 0 32px;
  line-height: 1.6;
}

/* Hero Visual */
.hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.lens-ring {
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: linear-gradient(135deg, #fef3c7 0%, #fed7aa 50%, #fde68a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 20px 60px rgba(146, 64, 14, 0.15),
    inset 0 2px 20px rgba(255, 255, 255, 0.3);
  animation: float 6s ease-in-out infinite;
}

.lens-ring-inner {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1c1917 0%, #292524 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #78716c;
  box-shadow: inset 0 4px 20px rgba(0, 0, 0, 0.4);
}

@keyframes float {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }
}

/* Hero Chat Starter */
.hero-chat-starter {
  margin-bottom: 32px;
}

.chat-form {
  margin-bottom: 16px;
}

.chat-input-wrapper {
  display: flex;
  gap: 12px;
  padding: 8px;
  background: var(--panel-strong);
  border-radius: 16px;
  border: 1px solid var(--stroke);
  box-shadow: 0 4px 20px rgba(16, 19, 26, 0.08);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.chat-input-wrapper:focus-within {
  border-color: #92400e;
  box-shadow: 0 4px 20px rgba(146, 64, 14, 0.15);
}

.chat-input {
  flex: 1 1;
  border: none;
  background: transparent;
  padding: 14px 16px;
  font-size: 16px;
  font-family: inherit;
  color: var(--ink);
  outline: none;
}

.chat-input::placeholder {
  color: var(--ink-soft);
}

.chat-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: none;
  border-radius: 12px;
  background: linear-gradient(135deg, #92400e 0%, #78350f 100%);
  color: #fff;
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.chat-submit:hover:not(:disabled) {
  transform: scale(1.05);
}

.chat-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Quick Chips */
.quick-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.quick-chip {
  padding: 10px 18px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid var(--stroke);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-soft);
  cursor: pointer;
  transition: all 0.2s ease;
}

.quick-chip:hover {
  background: #fef3c7;
  border-color: #fcd34d;
  color: #92400e;
  transform: translateY(-1px);
}

/* Trust Badges */
.trust-badges {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}

.trust-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--ink-soft);
}

.trust-badge svg {
  color: #059669;
}

/* Landing Section */
.landing-section {
  padding: 48px 0;
}

/* Popular Picks */
.popular-picks {
  background: var(--panel-strong);
  border-radius: var(--radius);
  padding: 32px;
  box-shadow: var(--shadow);
  border: 1px solid var(--stroke);
}

/* Dark Theme Landing Page - Full Bleed Immersive */
.landing-page-cinematic {
  background: linear-gradient(180deg, #1c1917 0%, #0c0a09 100%);
  min-height: 100vh;
  position: relative;
  isolation: isolate;
  /* Creates stacking context to cover body::before/after */
}

.landing-section-dark {
  padding: 60px 24px 80px;
  max-width: 1200px;
  margin: 0 auto;
}

.landing-section-dark .popular-picks {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
}

.landing-section-dark .popular-header h2 {
  color: #fff;
}

.landing-section-dark .popular-header svg {
  color: #fbbf24;
}

.landing-section-dark .see-all-link {
  color: rgba(255, 255, 255, 0.6);
}

.landing-section-dark .see-all-link:hover {
  color: #fbbf24;
}

.landing-section-dark .pick-card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.landing-section-dark .pick-card:hover {
  border-color: rgba(251, 191, 36, 0.3);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
}

.landing-section-dark .pick-info {
  background: rgba(0, 0, 0, 0.4);
}

.landing-section-dark .pick-brand {
  color: rgba(251, 191, 36, 0.8);
}

.landing-section-dark .pick-name {
  color: rgba(255, 255, 255, 0.9);
}

.landing-section-dark .pick-price {
  color: #fbbf24;
}

.popular-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
}

.popular-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 24px;
  font-weight: 600;
  margin: 0;
  color: var(--ink);
}

.popular-icon {
  color: #f59e0b;
}

.see-all-link {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 14px;
  font-weight: 500;
  color: var(--accent);
  transition: gap 0.2s ease;
}

.see-all-link:hover {
  gap: 8px;
}

/* Picks Grid */
.picks-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  grid-gap: 20px;
  gap: 20px;
}

.pick-card {
  background: #fff;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  overflow: hidden;
  transition: all 0.2s ease;
  text-decoration: none;
  color: inherit;
}

.pick-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(16, 19, 26, 0.1);
  border-color: #fcd34d;
}

.pick-image-wrapper {
  position: relative;
  aspect-ratio: 1;
  background: #fafaf9;
  overflow: hidden;
}

.pick-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.pick-card:hover .pick-image {
  transform: scale(1.05);
}

.pick-image-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #d1d5db;
}

.pick-grade {
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 4px 10px;
  background: var(--gold);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  border-radius: 999px;
}

.pick-info {
  padding: 16px;
}

.pick-brand {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 4px;
}

.pick-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 4px;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.pick-mount {
  display: block;
  font-size: 12px;
  color: var(--ink-soft);
  margin-bottom: 8px;
}

.pick-price {
  display: block;
  font-size: 16px;
  font-weight: 700;
  color: #92400e;
}

/* Responsive */
@media (max-width: 1024px) {
  .landing-hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 32px 0;
  }

  .hero-visual {
    order: -1;
  }

  .lens-ring {
    width: 200px;
    height: 200px;
  }

  .lens-ring-inner {
    width: 140px;
    height: 140px;
  }

  .lens-ring-inner svg {
    width: 50px;
    height: 50px;
  }
}

@media (max-width: 720px) {
  .hero-title {
    font-size: 32px;
  }

  .hero-subtitle {
    font-size: 16px;
  }

  .trust-badges {
    gap: 16px;
  }

  .trust-badge {
    font-size: 12px;
  }

  .picks-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }

  .pick-info {
    padding: 12px;
  }

  .pick-name {
    font-size: 13px;
  }

  .pick-price {
    font-size: 14px;
  }

  .popular-picks {
    padding: 20px;
  }

  .landing-section {
    padding: 24px 0;
  }

  .hero-visual {
    display: none;
  }
}

/* ============================================
   CINEMATIC LANDING HERO
   ============================================ */

.landing-hero-cinematic {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: linear-gradient(135deg, #0c0a09 0%, #1c1917 50%, #292524 100%);
}

/* Bokeh Canvas */
.bokeh-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1.5s ease;
}

.phase-reveal .bokeh-canvas,
.phase-complete .bokeh-canvas {
  opacity: 1;
}

/* Light Leak Effects */
.light-leaks {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: hidden;
}

.light-leak {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0;
  mix-blend-mode: screen;
}

.leak-1 {
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(251, 191, 36, 0.4) 0%, transparent 70%);
  top: -100px;
  right: -100px;
  animation: leak-drift-1 15s ease-in-out infinite;
}

.leak-2 {
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(245, 158, 11, 0.3) 0%, transparent 70%);
  bottom: 20%;
  left: -50px;
  animation: leak-drift-2 12s ease-in-out infinite;
}

.leak-3 {
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(217, 119, 6, 0.2) 0%, transparent 70%);
  top: 40%;
  right: 10%;
  animation: leak-drift-3 18s ease-in-out infinite;
}

.phase-reveal .light-leak,
.phase-complete .light-leak {
  opacity: 1;
  transition: opacity 2s ease 0.5s;
}

@keyframes leak-drift-1 {

  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }

  50% {
    transform: translate(-30px, 40px) scale(1.1);
  }
}

@keyframes leak-drift-2 {

  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }

  50% {
    transform: translate(40px, -30px) scale(1.15);
  }
}

@keyframes leak-drift-3 {

  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }

  50% {
    transform: translate(-20px, 20px) scale(1.05);
  }
}

/* Aperture Overlay */
.aperture-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  pointer-events: none;
  background: #0c0a09;
  transition: opacity 0.8s ease;
}

.phase-reveal .aperture-overlay,
.phase-complete .aperture-overlay {
  opacity: 0;
  pointer-events: none;
}

.aperture-svg {
  width: min(90vw, 90vh);
  height: min(90vw, 90vh);
}

.aperture-blade {
  fill: #1c1917;
  transform-origin: 50% 50%;
  transition: transform 1.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.phase-loading .aperture-blade {
  transform: rotate(0deg);
}

.phase-aperture .aperture-blade {
  transform: rotate(22.5deg) scale(0.3);
}

.phase-reveal .aperture-blade,
.phase-complete .aperture-blade {
  transform: rotate(45deg) scale(0);
}

/* Center loading indicator */
.aperture-overlay::after {
  content: "";
  position: absolute;
  width: 60px;
  height: 60px;
  border: 3px solid rgba(251, 191, 36, 0.2);
  border-top-color: #fbbf24;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  opacity: 1;
  transition: opacity 0.3s ease;
}

.phase-aperture .aperture-overlay::after,
.phase-reveal .aperture-overlay::after,
.phase-complete .aperture-overlay::after {
  opacity: 0;
}

/* Floating Lens Elements */
.floating-elements {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1.5s ease 0.5s;
}

.phase-reveal .floating-elements,
.phase-complete .floating-elements {
  opacity: 1;
}

.floating-lens {
  position: absolute;
  color: rgba(251, 191, 36, 0.15);
}

.floating-lens.lens-1 {
  width: 300px;
  height: 300px;
  top: 10%;
  right: 5%;
  animation: float-1 20s ease-in-out infinite;
}

.floating-lens.lens-2 {
  width: 200px;
  height: 200px;
  bottom: 15%;
  left: 8%;
  animation: float-2 15s ease-in-out infinite;
}

.floating-lens.lens-3 {
  width: 400px;
  height: 400px;
  top: 50%;
  left: -100px;
  animation: float-3 25s ease-in-out infinite;
}

@keyframes float-1 {

  0%,
  100% {
    transform: translate(0, 0) rotate(0deg);
  }

  25% {
    transform: translate(-20px, 30px) rotate(5deg);
  }

  50% {
    transform: translate(10px, -20px) rotate(-3deg);
  }

  75% {
    transform: translate(30px, 10px) rotate(8deg);
  }
}

@keyframes float-2 {

  0%,
  100% {
    transform: translate(0, 0) rotate(0deg);
  }

  33% {
    transform: translate(40px, -20px) rotate(-10deg);
  }

  66% {
    transform: translate(-20px, 30px) rotate(5deg);
  }
}

@keyframes float-3 {

  0%,
  100% {
    transform: translate(0, 0) rotate(0deg);
  }

  50% {
    transform: translate(50px, -30px) rotate(15deg);
  }
}

/* Main Content */
.hero-main-content {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 40px 24px;
  max-width: 800px;
  opacity: 0;
  transform: translateY(40px);
  transition: all 1s cubic-bezier(0.22, 1, 0.36, 1) 0.3s;
}

.phase-reveal .hero-main-content,
.phase-complete .hero-main-content {
  opacity: 1;
  transform: translateY(0);
}

/* Mint Introduction */
.mint-intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  margin-bottom: 32px;
  opacity: 0;
  transform: scale(0.8);
  transition: all 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.8s;
}

.phase-reveal .mint-intro,
.phase-complete .mint-intro {
  opacity: 1;
  transform: scale(1);
}

.mint-avatar-large {
  width: 80px;
  height: 80px;
  border-radius: 24px;
  background: linear-gradient(145deg, #fef3c7 0%, #fde68a 50%, #fbbf24 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  box-shadow:
    0 4px 20px rgba(251, 191, 36, 0.4),
    0 0 60px rgba(251, 191, 36, 0.2);
  animation: avatar-glow 3s ease-in-out infinite;
  overflow: hidden;
  /* Ensure image stays within border radius */
}

.mint-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
  /* Should inherit from parent, but safe to specify */
}

/* Removed specific span styling as it's replaced by img */
.mint-avatar-large span {
  display: none;
}

.mint-avatar-large .mint-status {
  position: absolute;
  bottom: -4px;
  right: -4px;
  width: 20px;
  height: 20px;
  background: linear-gradient(135deg, #10b981 0%, #059669 100%);
  border-radius: 50%;
  border: 3px solid #1c1917;
  animation: pulse-status 2s ease-in-out infinite;
}

@keyframes avatar-glow {

  0%,
  100% {
    box-shadow: 0 4px 20px rgba(251, 191, 36, 0.4), 0 0 60px rgba(251, 191, 36, 0.2);
  }

  50% {
    box-shadow: 0 4px 30px rgba(251, 191, 36, 0.6), 0 0 80px rgba(251, 191, 36, 0.3);
  }
}

@keyframes pulse-status {

  0%,
  100% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.1);
  }
}

.mint-greeting {
  background: rgba(255, 255, 255, 0.05);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  padding: 8px 20px;
}

.greeting-text {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.8);
  font-weight: 500;
}

/* Hero Title with Character Animation */
.hero-title-cinematic {
  font-family: var(--font-display), Georgia, serif;
  font-size: clamp(36px, 8vw, 64px);
  font-weight: 700;
  color: #fff;
  margin: 0 0 16px;
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.title-line {
  display: inline-block;
}

.title-line .char {
  display: inline-block;
  opacity: 0;
  transform: translateY(30px) rotateX(-90deg);
  animation: char-reveal 0.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

@keyframes char-reveal {
  to {
    opacity: 1;
    transform: translateY(0) rotateX(0);
  }
}

/* Hero Subtitle */
.hero-subtitle-cinematic {
  font-size: clamp(16px, 3vw, 20px);
  color: rgba(255, 255, 255, 0.6);
  margin: 0 0 40px;
  max-width: 500px;
  line-height: 1.6;
  opacity: 0;
  transform: translateY(20px);
  animation: fade-up 0.8s ease forwards 2.2s;
}

@keyframes fade-up {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Chat Preview Container - shows greeting to clarify it's a chat */
.chat-preview-container {
  width: 100%;
  max-width: 520px;
  margin-bottom: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.chat-bubble-mint {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 18px;
  background: rgba(28, 25, 23, 0.65);
  border: 1px solid rgba(202, 138, 4, 0.2);
  border-radius: 20px;
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  opacity: 0;
  transform: translateY(15px);
  animation: fade-up 0.6s ease forwards;
}

.chat-bubble-mint .bubble-avatar {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(202, 138, 4, 0.3);
}

.chat-bubble-mint .bubble-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.chat-bubble-mint .bubble-content {
  flex: 1 1;
  min-width: 0;
  text-align: left;
}

.chat-bubble-mint .bubble-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: #ca8a04;
  margin-bottom: 6px;
  text-align: left;
}

.chat-bubble-mint .bubble-content p {
  margin: 0 0 6px 0;
  font-size: 15px;
  line-height: 1.5;
  color: #fef3c7;
  text-align: left;
}

.chat-bubble-mint .bubble-content p:last-child {
  margin-bottom: 0;
}

/* Chat Input Form */
.hero-chat-form {
  width: 100%;
  max-width: 560px;
  margin-bottom: 24px;
  opacity: 0;
  transform: translateY(20px);
  animation: fade-up 0.8s ease forwards 2.4s;
}

.chat-input-container {
  position: relative;
  display: flex;
  gap: 12px;
  background: rgba(255, 255, 255, 0.05);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 16px;
  padding: 8px;
  transition: all 0.3s ease;
}

.chat-input-container:focus-within {
  border-color: rgba(251, 191, 36, 0.5);
  box-shadow: 0 0 0 4px rgba(251, 191, 36, 0.1);
}

.input-glow {
  position: absolute;
  top: -1px;
  left: -1px;
  right: -1px;
  bottom: -1px;
  border-radius: 17px;
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.3), transparent, rgba(245, 158, 11, 0.3));
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  z-index: -1;
}

.chat-input-container:focus-within .input-glow {
  opacity: 1;
}

.hero-chat-input {
  flex: 1 1;
  background: transparent;
  border: none;
  padding: 14px 16px;
  font-size: 16px;
  color: #fff;
  outline: none;
}

.hero-chat-input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.hero-submit-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 24px;
  background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
  border: none;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 600;
  color: #1c1917;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.hero-submit-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(251, 191, 36, 0.4);
}

.hero-submit-btn:active {
  transform: translateY(0) scale(0.98);
}

.hero-submit-btn svg {
  transition: transform 0.3s ease;
}

.hero-submit-btn:hover svg {
  transform: translateX(3px) translateY(-3px);
}

/* Quick Chips */
.hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-bottom: 40px;
  opacity: 0;
  animation: fade-up 0.8s ease forwards 2.6s;
}

.hero-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  background: rgba(255, 255, 255, 0.05);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.8);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.hero-chip:hover {
  background: rgba(251, 191, 36, 0.15);
  border-color: rgba(251, 191, 36, 0.3);
  color: #fbbf24;
  transform: translateY(-2px);
}

.hero-chip:active {
  transform: translateY(0) scale(0.97);
}

.chip-icon {
  font-size: 16px;
}

/* Trust Badges */
.hero-trust-badges {
  display: flex;
  gap: 32px;
  opacity: 0;
  animation: fade-up 0.8s ease forwards 2.8s;
}

.trust-badge-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.5);
}

.trust-badge-item svg {
  color: rgba(251, 191, 36, 0.6);
}

/* Scroll Indicator */
.scroll-indicator {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  opacity: 0;
  animation: fade-up 0.8s ease forwards 3s, bounce-gentle 2s ease-in-out infinite 3.5s;
}

.scroll-indicator span {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.scroll-mouse {
  width: 24px;
  height: 40px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-radius: 12px;
  position: relative;
}

.scroll-wheel {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 8px;
  background: rgba(251, 191, 36, 0.6);
  border-radius: 2px;
  animation: scroll-wheel 1.5s ease-in-out infinite;
}

@keyframes scroll-wheel {

  0%,
  100% {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }

  50% {
    opacity: 0.3;
    transform: translateX(-50%) translateY(12px);
  }
}

@keyframes bounce-gentle {

  0%,
  100% {
    transform: translateX(-50%) translateY(0);
  }

  50% {
    transform: translateX(-50%) translateY(-8px);
  }
}

/* Phase: Complete - enable interactions */
.phase-complete .hero-chat-form,
.phase-complete .hero-chips,
.phase-complete .scroll-indicator {
  pointer-events: auto;
}

/* Responsive */
@media (max-width: 720px) {
  .landing-hero-cinematic {
    min-height: 100svh;
    padding-bottom: 80px;
  }

  .hero-main-content {
    padding: 24px 16px;
  }

  .mint-avatar-large {
    width: 64px;
    height: 64px;
    border-radius: 18px;
  }

  .mint-avatar-large span {
    font-size: 28px;
  }

  .hero-subtitle-cinematic {
    margin-bottom: 32px;
  }

  .chat-input-container {
    flex-direction: column;
    gap: 8px;
  }

  .hero-submit-btn {
    width: 100%;
    justify-content: center;
  }

  .hero-chips {
    gap: 8px;
  }

  .hero-chip {
    padding: 8px 14px;
    font-size: 13px;
  }

  .hero-trust-badges {
    flex-direction: column;
    gap: 12px;
  }

  .floating-elements {
    display: none;
  }

  .scroll-indicator {
    bottom: 24px;
  }
}

/* Reduced motion preference */
@media (prefers-reduced-motion: reduce) {

  .aperture-blade,
  .light-leak,
  .floating-lens,
  .mint-avatar-large,
  .scroll-wheel,
  .title-line .char {
    animation: none !important;
  }

  .phase-loading .aperture-overlay,
  .phase-aperture .aperture-overlay {
    display: none;
  }

  .hero-main-content,
  .mint-intro,
  .hero-subtitle-cinematic,
  .hero-chat-form,
  .hero-chips,
  .hero-trust-badges,
  .scroll-indicator {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }

  .title-line .char {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* ============================================
   Assistant Page Styles
   ============================================ */

.assistant-page {
  min-height: calc(100vh - 100px);
  display: flex;
  flex-direction: column;
}

.assistant-header {
  display: flex;
  align-items: center;
  gap: 24px;
  margin-bottom: 32px;
}

.back-link {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  color: var(--ink-soft);
  transition: color 0.2s ease;
}

.back-link:hover {
  color: var(--accent);
}

.assistant-title {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 28px;
  font-weight: 600;
  margin: 0;
  color: var(--ink);
}

/* Mint Header Styling */
.assistant-title-group {
  display: flex;
  align-items: center;
  gap: 14px;
}

.mint-avatar-header {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: linear-gradient(145deg, #fef3c7 0%, #fde68a 50%, #fcd34d 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  box-shadow: 0 2px 12px rgba(251, 191, 36, 0.3);
}

.mint-avatar-header::before {
  content: "M";
  font-family: var(--font-display), Georgia, serif;
  font-size: 22px;
  font-weight: 700;
  color: #92400e;
}

.mint-avatar-header::after {
  content: "";
  position: absolute;
  bottom: -3px;
  right: -3px;
  width: 14px;
  height: 14px;
  background: linear-gradient(135deg, #10b981 0%, #059669 100%);
  border-radius: 50%;
  border: 2px solid #fff;
}

.assistant-title-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.assistant-title-text .assistant-title {
  font-size: 22px;
  line-height: 1.2;
}

.assistant-subtitle {
  font-size: 13px;
  color: var(--ink-soft);
  font-weight: 400;
}

.assistant-coming-soon {
  flex: 1 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px 24px;
  background: var(--panel-strong);
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow);
}

.coming-soon-icon {
  width: 80px;
  height: 80px;
  border-radius: 20px;
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #92400e;
  margin-bottom: 24px;
}

.assistant-coming-soon h2 {
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 28px;
  font-weight: 600;
  margin: 0 0 12px;
  color: var(--ink);
}

.assistant-coming-soon p {
  font-size: 15px;
  color: var(--ink-soft);
  margin: 0 0 24px;
  max-width: 400px;
}

.initial-query {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px 24px;
  background: #fafaf9;
  border-radius: 12px;
  margin-bottom: 24px;
}

.query-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
  font-weight: 600;
}

.query-text {
  font-size: 16px;
  color: var(--ink);
  font-style: italic;
}

.assistant-cta {
  margin-top: 8px;
}

/* Assistant Layout */
.assistant-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 24px;
  gap: 24px;
  min-height: calc(100vh - 200px);
}

.chat-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 12px 12px 0;
}

.chat-history-toggle {
  border: none;
  background: rgba(255, 111, 60, 0.12);
  color: var(--accent);
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 12px;
  cursor: pointer;
}

.chat-end-toggle {
  border: none;
  background: linear-gradient(135deg, rgba(16, 19, 26, 0.14), rgba(16, 19, 26, 0.05));
  color: var(--ink);
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: 0.02em;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(16, 19, 26, 0.08);
  transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.chat-end-toggle:hover {
  background: linear-gradient(135deg, rgba(16, 19, 26, 0.2), rgba(16, 19, 26, 0.08));
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(16, 19, 26, 0.12);
}

.chat-end-toggle:active {
  transform: translateY(0);
  box-shadow: 0 6px 14px rgba(16, 19, 26, 0.1);
}

.chat-end-toggle:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  box-shadow: none;
}

.chat-history-panel {
  background: var(--panel-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 70vh;
  overflow: auto;
}

.chat-history-header h3 {
  margin: 0;
  font-size: 16px;
  font-family: var(--font-display);
}

.chat-history-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.chat-history-item {
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.7);
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.chat-history-item strong {
  font-size: 13px;
  color: var(--ink);
}

.chat-history-item span {
  font-size: 11px;
  color: var(--ink-soft);
}

.chat-history-item.is-active {
  border-color: rgba(255, 111, 60, 0.4);
  background: rgba(255, 111, 60, 0.08);
}

.chat-history-empty {
  font-size: 12px;
  color: var(--ink-soft);
}

.assistant-chat-panel {
  display: flex;
  flex-direction: column;
  background: var(--panel-strong);
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.assistant-recommendation-panel {
  display: flex;
  flex-direction: column;
}

/* Chat Transcript */
.chat-transcript {
  flex: 1 1;
  padding: 24px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-height: calc(100vh - 350px);
}

.chat-message {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.chat-message.user {
  justify-content: flex-end;
}

.chat-avatar {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chat-avatar.assistant {
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  color: #92400e;
}

.chat-avatar.user {
  background: var(--ink);
  color: #fff;
}

.chat-bubble {
  max-width: 80%;
  padding: 14px 18px;
  border-radius: 16px;
  line-height: 1.5;
}

.chat-bubble.assistant {
  background: #f5f5f4;
  border-radius: 16px 16px 16px 4px;
  color: var(--ink);
}

.chat-bubble.user {
  background: linear-gradient(135deg, #92400e 0%, #78350f 100%);
  border-radius: 16px 16px 4px 16px;
  color: #fff;
}

.chat-content {
  white-space: pre-wrap;
  word-wrap: break-word;
}

/* Typing Indicator */
.typing-indicator {
  display: flex;
  gap: 4px;
  padding: 4px 0;
}

.typing-indicator span {
  width: 8px;
  height: 8px;
  background: #a8a29e;
  border-radius: 50%;
  animation: typing-bounce 1.4s infinite ease-in-out;
}

.typing-indicator span:nth-child(1) {
  animation-delay: 0s;
}

.typing-indicator span:nth-child(2) {
  animation-delay: 0.2s;
}

.typing-indicator span:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes typing-bounce {

  0%,
  60%,
  100% {
    transform: translateY(0);
  }

  30% {
    transform: translateY(-6px);
  }
}

/* Chat Input Area */
.chat-input-area {
  padding: 16px 20px;
  border-top: 1px solid var(--stroke);
  background: #fafaf9;
}

.message-input-form {
  margin-top: 12px;
}

.message-input-wrapper {
  display: flex;
  gap: 12px;
  background: #fff;
  border: 1px solid var(--stroke);
  border-radius: 14px;
  padding: 6px;
  transition: border-color 0.2s ease;
}

.message-input-wrapper:focus-within {
  border-color: #92400e;
}

.message-textarea {
  flex: 1 1;
  border: none;
  background: transparent;
  padding: 10px 12px;
  font-size: 15px;
  font-family: inherit;
  color: var(--ink);
  resize: none;
  outline: none;
  min-height: 24px;
  max-height: 120px;
}

.message-textarea::placeholder {
  color: var(--ink-soft);
}

.message-send-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(135deg, #92400e 0%, #78350f 100%);
  color: #fff;
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.message-send-btn:hover:not(:disabled) {
  transform: scale(1.05);
}

.message-send-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.message-send-btn .spinner {
  animation: spin 1s linear infinite;
}

/* Quick Replies */
.quick-replies-container {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.quick-reply-btn {
  padding: 8px 16px;
  background: #fff;
  border: 1px solid var(--stroke);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-soft);
  cursor: pointer;
  transition: all 0.2s ease;
}

.quick-reply-btn:hover:not(:disabled) {
  background: #fef3c7;
  border-color: #fcd34d;
  color: #92400e;
}

.quick-reply-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Recommendation Panel */
.recommendation-panel {
  background: var(--panel-strong);
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow);
  padding: 24px;
  height: -moz-fit-content;
  height: fit-content;
  max-height: calc(100vh - 200px);
  overflow-y: auto;
}

.recommendation-panel.empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 300px;
}

.recommendation-empty {
  text-align: center;
  color: var(--ink-soft);
}

.recommendation-empty svg {
  margin-bottom: 16px;
  opacity: 0.5;
}

.recommendation-empty p {
  margin: 0;
  font-size: 14px;
}

.recommendation-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.recommendation-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display), "Times New Roman", serif;
  font-size: 20px;
  font-weight: 600;
  margin: 0;
  color: var(--ink);
}

.recommendation-title svg {
  color: var(--accent);
}

.recommendation-count {
  font-size: 13px;
  color: var(--ink-soft);
  background: #f5f5f4;
  padding: 4px 12px;
  border-radius: 999px;
}

.recommendation-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Inventory Card */
.inventory-card {
  display: flex;
  gap: 16px;
  background: #fff;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  padding: 16px;
  transition: all 0.2s ease;
}

.inventory-card:hover {
  border-color: #fcd34d;
  box-shadow: 0 4px 12px rgba(16, 19, 26, 0.08);
}

.inventory-card-image {
  position: relative;
  width: 100px;
  height: 100px;
  border-radius: 10px;
  overflow: hidden;
  background: #fafaf9;
  flex-shrink: 0;
}

.inventory-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.inventory-card-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #d1d5db;
}

.inventory-card-grade {
  position: absolute;
  top: 6px;
  right: 6px;
  padding: 3px 8px;
  background: var(--gold);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  border-radius: 999px;
}

.inventory-card-body {
  flex: 1 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.inventory-card-brand {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gold);
  font-weight: 600;
}

.inventory-card-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  margin: 2px 0 4px;
  line-height: 1.3;
}

.inventory-card-mount {
  font-size: 12px;
  color: var(--ink-soft);
}

.inventory-card-price-row {
  margin-top: 8px;
}

.inventory-card-price {
  font-size: 18px;
  font-weight: 700;
  color: #92400e;
}

.inventory-card-why {
  margin-top: 12px;
  padding: 12px;
  background: #fef3c7;
  border-radius: 8px;
  font-size: 13px;
  color: #78350f;
  line-height: 1.5;
}

.inventory-card-why p {
  margin: 0;
  white-space: pre-wrap;
}

.inventory-card-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

.card-action-btn {
  flex: 1 1;
  padding: 10px 14px;
  border: none;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.card-action-btn.primary {
  background: linear-gradient(135deg, #059669 0%, #047857 100%);
  color: #fff;
}

.card-action-btn.primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(5, 150, 105, 0.3);
}

.card-action-btn.secondary {
  background: #f5f5f4;
  color: var(--ink-soft);
}

.card-action-btn.secondary:hover:not(:disabled) {
  background: #e7e5e4;
  color: var(--ink);
}

.card-action-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Assistant Loading */
.assistant-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  color: var(--ink-soft);
}

/* ============================================
   ENHANCED ASSISTANT ANIMATIONS & STYLING
   ============================================ */

/* Message Slide-in Animation */
@keyframes message-slide-in {
  0% {
    opacity: 0;
    transform: translateY(16px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes message-slide-in-left {
  0% {
    opacity: 0;
    transform: translateX(-20px);
  }

  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes message-slide-in-right {
  0% {
    opacity: 0;
    transform: translateX(20px);
  }

  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

.chat-message {
  animation: message-slide-in 0.3s ease-out forwards;
}

.chat-message.assistant {
  animation: message-slide-in-left 0.35s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.chat-message.user {
  animation: message-slide-in-right 0.35s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

/* Enhanced Mint Avatar */
.chat-avatar.assistant {
  background: linear-gradient(145deg, #fef3c7 0%, #fde68a 50%, #fcd34d 100%);
  color: #92400e;
  position: relative;
  font-size: 18px;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(251, 191, 36, 0.25);
}

.chat-avatar.assistant::before {
  content: "M";
  font-family: var(--font-display), Georgia, serif;
  font-size: 16px;
  font-weight: 700;
}

.chat-avatar.assistant::after {
  content: "";
  position: absolute;
  bottom: -2px;
  right: -2px;
  width: 12px;
  height: 12px;
  background: linear-gradient(135deg, #10b981 0%, #059669 100%);
  border-radius: 50%;
  border: 2px solid var(--panel-strong);
}

/* Enhanced Chat Bubbles */
.chat-bubble.assistant {
  background: linear-gradient(135deg, #fafaf9 0%, #f5f5f4 100%);
  border-radius: 18px 18px 18px 6px;
  color: var(--ink);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
  position: relative;
}

.chat-bubble.user {
  background: linear-gradient(135deg, #a16207 0%, #854d0e 50%, #713f12 100%);
  border-radius: 18px 18px 6px 18px;
  color: #fff;
  box-shadow: 0 2px 8px rgba(146, 64, 14, 0.2);
}

/* Markdown Rendering in Chat */
.chat-content h1,
.chat-content h2,
.chat-content h3 {
  font-family: var(--font-display), Georgia, serif;
  font-weight: 600;
  margin: 16px 0 8px 0;
  line-height: 1.3;
}

.chat-content h2 {
  font-size: 16px;
  color: #78350f;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  padding-bottom: 6px;
}

.chat-content h3 {
  font-size: 14px;
  color: var(--ink);
}

.chat-content ul,
.chat-content ol {
  margin: 8px 0;
  padding-left: 20px;
}

.chat-content li {
  margin: 4px 0;
  line-height: 1.5;
}

.chat-content strong {
  font-weight: 600;
  color: #78350f;
}

.chat-content code {
  background: rgba(0, 0, 0, 0.05);
  padding: 2px 6px;
  border-radius: 4px;
  font-family: ui-monospace, monospace;
  font-size: 13px;
}

.chat-content a {
  color: #92400e;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.chat-content a:hover {
  color: #78350f;
}

.chat-content p {
  margin: 8px 0;
}

.chat-content p:first-child {
  margin-top: 0;
}

.chat-content p:last-child {
  margin-bottom: 0;
}

/* Card Stagger Animation */
@keyframes card-fade-in {
  0% {
    opacity: 0;
    transform: translateY(20px) scale(0.97);
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.inventory-card {
  animation: card-fade-in 0.4s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  opacity: 0;
}

.inventory-card:nth-child(1) {
  animation-delay: 0.05s;
}

.inventory-card:nth-child(2) {
  animation-delay: 0.12s;
}

.inventory-card:nth-child(3) {
  animation-delay: 0.19s;
}

.inventory-card:nth-child(4) {
  animation-delay: 0.26s;
}

.inventory-card:nth-child(5) {
  animation-delay: 0.33s;
}

/* Enhanced Card Hover */
.inventory-card {
  transition: all 0.25s cubic-bezier(0.22, 1, 0.36, 1);
  cursor: pointer;
}

.inventory-card:hover {
  border-color: #fcd34d;
  box-shadow:
    0 4px 6px -1px rgba(0, 0, 0, 0.05),
    0 10px 20px -3px rgba(251, 191, 36, 0.15);
  transform: translateY(-2px);
}

.inventory-card:hover .inventory-card-image img {
  transform: scale(1.05);
}

.inventory-card-image img {
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Enhanced Grade Badge */
.inventory-card-grade {
  background: linear-gradient(135deg, var(--gold) 0%, #b45309 100%);
  box-shadow: 0 2px 6px rgba(180, 83, 9, 0.3);
  font-size: 11px;
  padding: 4px 10px;
}

/* Quick Reply Animation */
@keyframes quick-reply-pop {
  0% {
    opacity: 0;
    transform: scale(0.8);
  }

  50% {
    transform: scale(1.02);
  }

  100% {
    opacity: 1;
    transform: scale(1);
  }
}

.quick-reply-btn {
  animation: quick-reply-pop 0.3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  opacity: 0;
}

.quick-reply-btn:nth-child(1) {
  animation-delay: 0.1s;
}

.quick-reply-btn:nth-child(2) {
  animation-delay: 0.15s;
}

.quick-reply-btn:nth-child(3) {
  animation-delay: 0.2s;
}

.quick-reply-btn:nth-child(4) {
  animation-delay: 0.25s;
}

.quick-reply-btn {
  transition: all 0.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.quick-reply-btn:hover:not(:disabled) {
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  border-color: #fbbf24;
  color: #92400e;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(251, 191, 36, 0.2);
}

.quick-reply-btn:active:not(:disabled) {
  transform: translateY(0) scale(0.98);
}

/* Skeleton Loading for Cards */
@keyframes skeleton-shimmer {
  0% {
    background-position: -200% 0;
  }

  100% {
    background-position: 200% 0;
  }
}

.skeleton {
  background: linear-gradient(90deg,
      #f0f0f0 25%,
      #e0e0e0 50%,
      #f0f0f0 75%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s infinite;
  border-radius: 8px;
}

.skeleton-card {
  display: flex;
  gap: 16px;
  background: #fff;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  padding: 16px;
}

.skeleton-card-image {
  width: 100px;
  height: 100px;
  border-radius: 10px;
}

.skeleton-card-body {
  flex: 1 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.skeleton-line {
  height: 14px;
}

.skeleton-line.short {
  width: 60%;
}

.skeleton-line.medium {
  width: 80%;
}

/* Enhanced Send Button */
.message-send-btn {
  background: linear-gradient(145deg, #a16207 0%, #854d0e 100%);
  box-shadow: 0 2px 8px rgba(146, 64, 14, 0.25);
}

.message-send-btn:hover:not(:disabled) {
  transform: scale(1.05);
  box-shadow: 0 4px 12px rgba(146, 64, 14, 0.35);
}

.message-send-btn:active:not(:disabled) {
  transform: scale(0.98);
}

/* Pulse animation for loading */
@keyframes pulse-glow {

  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(251, 191, 36, 0.4);
  }

  50% {
    box-shadow: 0 0 0 8px rgba(251, 191, 36, 0);
  }
}

.chat-message.assistant.loading .chat-avatar {
  animation: pulse-glow 2s ease-in-out infinite;
}

/* Smooth Scroll for Chat */
.chat-transcript {
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: #d6d3d1 transparent;
  overscroll-behavior-y: contain;
  /* Prevent pull-to-refresh or body scroll chaining */
  touch-action: pan-y;
}

.chat-transcript::-webkit-scrollbar {
  width: 6px;
}

.chat-transcript::-webkit-scrollbar-track {
  background: transparent;
}

.chat-transcript::-webkit-scrollbar-thumb {
  background: #d6d3d1;
  border-radius: 3px;
}

.chat-transcript::-webkit-scrollbar-thumb:hover {
  background: #a8a29e;
}

/* Recommendation Panel Enhancement */
.recommendation-panel {
  transition: all 0.3s ease;
}

.recommendation-panel:has(.inventory-card:hover) {
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
}

/* Empty State Enhancement */
.recommendation-empty {
  animation: message-slide-in 0.5s ease-out forwards;
}

.recommendation-empty svg {
  transition: transform 0.3s ease;
}

.recommendation-empty:hover svg {
  transform: scale(1.1) rotate(-5deg);
}

/* Chat Input Focus Enhancement */
.message-input-wrapper {
  transition: all 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}

.message-input-wrapper:focus-within {
  border-color: #a16207;
  box-shadow: 0 0 0 3px rgba(161, 98, 7, 0.1);
}

/* Action Button Press Effect */
.card-action-btn:active:not(:disabled) {
  transform: translateY(0) scale(0.97);
}

/* Why Text Animation */
@keyframes why-expand {
  0% {
    opacity: 0;
    max-height: 0;
    padding: 0 12px;
  }

  100% {
    opacity: 1;
    max-height: 200px;
    padding: 12px;
  }
}

.inventory-card-why {
  animation: why-expand 0.3s ease-out forwards;
  overflow: hidden;
}

/* Responsive */
@media (max-width: 1024px) {
  .assistant-layout {
    grid-template-columns: 1fr;
  }

  .assistant-chat-panel {
    min-height: 500px;
  }

  .chat-transcript {
    max-height: 400px;
  }

  .recommendation-panel {
    max-height: none;
  }
}

@media (max-width: 720px) {
  .assistant-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .inventory-card {
    flex-direction: column;
  }

  .inventory-card-image {
    width: 100%;
    height: 160px;
  }

  .chat-transcript {
    padding: 16px;
    max-height: 350px;
  }

  .chat-bubble {
    max-width: 90%;
    padding: 12px 14px;
  }
}

/* ===================== */
/* PROFILE PAGE STYLES   */
/* ===================== */

.profile-page {
  min-height: 100vh;
  padding: 0;
  animation: fadeIn 0.4s ease-out;
  background: linear-gradient(180deg, #0c0a09 0%, #1c1917 100%);
}

/* ===================== */
/* COLLECTIBLE PROFILE   */
/* Premium Trophy Shelf  */
/* ===================== */

.collectible-profile {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Cinematic Hero Section */
.collectible-hero {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 32px;
  padding: 48px 40px;
  background: linear-gradient(135deg, #1c1917 0%, #292524 50%, #1c1917 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  position: relative;
  overflow: hidden;
}

.collectible-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 600px 400px at 20% 50%, rgba(251, 146, 60, 0.12), transparent),
    radial-gradient(ellipse 500px 300px at 80% 30%, rgba(245, 158, 11, 0.08), transparent);
  pointer-events: none;
}

.collectible-hero::after {
  content: "";
  position: absolute;
  width: 500px;
  height: 500px;
  right: -150px;
  top: -200px;
  background: radial-gradient(circle, rgba(251, 146, 60, 0.15), transparent 60%);
  filter: blur(60px);
  animation: float 8s ease-in-out infinite;
}

@keyframes float {

  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }

  50% {
    transform: translateY(-20px) rotate(5deg);
  }
}

.collectible-hero-main {
  display: flex;
  align-items: center;
  gap: 28px;
  z-index: 1;
}

.collectible-hero .profile-avatar {
  width: 100px;
  height: 100px;
  border: 3px solid rgba(251, 146, 60, 0.4);
  box-shadow: 0 0 40px rgba(251, 146, 60, 0.2);
}

.collectible-hero .profile-avatar-placeholder {
  background: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
  font-size: 40px;
}

.collectible-hero-text {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.collectible-hero-name {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 700;
  color: #fafaf9;
  letter-spacing: -0.02em;
}

.collectible-hero-tagline {
  font-size: 13px;
  color: rgba(250, 250, 249, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-weight: 500;
}

.collectible-hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 13px;
  margin-top: 4px;
}

.collectible-hero-stats span {
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(250, 250, 249, 0.9);
  font-weight: 500;
  transition: all 0.25s ease;
}

.collectible-hero-stats span:hover {
  background: rgba(251, 146, 60, 0.15);
  border-color: rgba(251, 146, 60, 0.3);
}

.collectible-hero-actions {
  display: flex;
  gap: 12px;
  z-index: 1;
}

.collectible-hero-actions .btn-primary {
  background: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
  border: none;
  color: white;
  padding: 14px 28px;
  border-radius: 14px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.25s ease;
  box-shadow: 0 8px 24px rgba(249, 115, 22, 0.3);
}

.collectible-hero-actions .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(249, 115, 22, 0.4);
}

.collectible-hero-actions .btn-secondary {
  background: rgba(255, 255, 255, 0.06);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(250, 250, 249, 0.9);
  padding: 14px 28px;
  border-radius: 14px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.25s ease;
}

.collectible-hero-actions .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

/* Tab Navigation */
.collectible-tabs {
  display: flex;
  gap: 0;
  padding: 0;
  background: #1c1917;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  width: 100%;
}

.collectible-tabs button {
  border: none;
  background: transparent;
  padding: 18px 32px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  color: rgba(250, 250, 249, 0.5);
  transition: all 0.25s ease;
  position: relative;
}

.collectible-tabs button::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: transparent;
  transition: all 0.25s ease;
}

.collectible-tabs button:hover {
  color: rgba(250, 250, 249, 0.8);
}

.collectible-tabs button.is-active {
  color: #fb923c;
  background: transparent;
  box-shadow: none;
}

.collectible-tabs button.is-active::after {
  background: linear-gradient(90deg, #f97316, #fb923c);
}

/* Collection Layout - Dark Theme */
.collection-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  grid-gap: 0;
  gap: 0;
  background: #0c0a09;
  min-height: calc(100vh - 200px);
}

.collection-main {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 28px 32px;
  border-right: 1px solid rgba(255, 255, 255, 0.06);
}

/* Stats Card - Glass Effect */
.collection-stats-card {
  padding: 24px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.03);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.06);
  margin-bottom: 24px;
}

.collection-stats-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.collection-stats-header h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 18px;
  color: #fafaf9;
  font-weight: 600;
}

.collection-stats-pill {
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  background: rgba(251, 146, 60, 0.15);
  color: #fb923c;
  border: 1px solid rgba(251, 146, 60, 0.2);
}

.collection-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 20px;
  gap: 20px;
}

.collection-stats-grid>div {
  padding: 16px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.04);
  transition: all 0.25s ease;
}

.collection-stats-grid>div:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(251, 146, 60, 0.2);
}

.collection-stats-grid p {
  margin: 0 0 8px 0;
  font-size: 11px;
  color: rgba(250, 250, 249, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 500;
}

.collection-stats-grid strong {
  font-size: 24px;
  font-family: var(--font-display);
  color: #fafaf9;
  font-weight: 700;
}

/* Filter Controls */
.collection-controls {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 24px;
}

.collection-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.collection-filters button {
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 10px 18px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  color: rgba(250, 250, 249, 0.6);
  transition: all 0.25s ease;
}

.collection-filters button:hover {
  background: rgba(255, 255, 255, 0.06);
  color: rgba(250, 250, 249, 0.9);
}

.collection-filters button.is-active {
  background: linear-gradient(135deg, #f97316, #ea580c);
  border-color: transparent;
  color: white;
  box-shadow: 0 4px 16px rgba(249, 115, 22, 0.3);
}

.collection-search {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.collection-search input,
.collection-search select {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 12px 16px;
  font-size: 13px;
  background: rgba(255, 255, 255, 0.03);
  color: #fafaf9;
  font-family: inherit;
  transition: all 0.25s ease;
}

.collection-search input::placeholder {
  color: rgba(250, 250, 249, 0.3);
}

.collection-search input:focus,
.collection-search select:focus {
  outline: none;
  border-color: rgba(251, 146, 60, 0.4);
  background: rgba(255, 255, 255, 0.05);
}

.collection-search input {
  flex: 1 1;
  min-width: 200px;
}

.collection-search select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(250,250,249,0.5)' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/* Collection Grid - Trophy Shelf */
.collection-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 20px;
  gap: 20px;
}

.collection-card {
  background: rgba(255, 255, 255, 0.02);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-align: left;
  cursor: pointer;
  padding: 0;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}

.collection-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 20px;
  padding: 1px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), transparent 50%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.collection-card:hover {
  transform: translateY(-6px);
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(251, 146, 60, 0.3);
  box-shadow:
    0 20px 40px rgba(0, 0, 0, 0.4),
    0 0 60px rgba(251, 146, 60, 0.1);
}

.collection-card:hover::before {
  opacity: 1;
}

.collection-card-image {
  height: 140px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: 700;
  color: white;
  position: relative;
  overflow: hidden;
}

.collection-card-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0, 0, 0, 0.4) 100%);
}

.collection-card-image.vintage {
  background: linear-gradient(145deg, #92400e 0%, #451a03 100%);
}

.collection-card-image.modern {
  background: linear-gradient(145deg, #1e40af 0%, #0f172a 100%);
}

.collection-card-image.cameras {
  background: linear-gradient(145deg, #047857 0%, #022c22 100%);
}

.collection-card-image.wishlist {
  background: linear-gradient(145deg, #7e22ce 0%, #3b0764 100%);
}

.collection-pin {
  position: absolute;
  top: 12px;
  right: 12px;
  font-size: 9px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.15);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  z-index: 1;
  font-weight: 600;
}

.collection-card-body {
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.collection-card-title {
  font-size: 16px;
  font-weight: 600;
  color: #fafaf9;
}

.collection-card-meta {
  font-size: 12px;
  color: rgba(250, 250, 249, 0.5);
}

.collection-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 4px;
}

.collection-stars {
  display: flex;
  gap: 3px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.15);
}

.collection-stars .is-active {
  color: #fbbf24;
  text-shadow: 0 0 10px rgba(251, 191, 36, 0.4);
}

.collection-source {
  font-size: 10px;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.collection-source.lensseed {
  background: rgba(251, 146, 60, 0.15);
  color: #fb923c;
  border: 1px solid rgba(251, 146, 60, 0.2);
}

.collection-source.manual {
  background: rgba(255, 255, 255, 0.05);
  color: rgba(250, 250, 249, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

/* Sidebar */
.collection-side {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 28px 24px;
  background: rgba(255, 255, 255, 0.01);
}

/* Modal - Dark Glass */
.lens-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.8);
  -webkit-backdrop-filter: blur(12px);
          backdrop-filter: blur(12px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 50;
}

.lens-modal {
  width: min(960px, 100%);
  max-height: 88vh;
  overflow: auto;
  background: linear-gradient(180deg, #1c1917 0%, #0c0a09 100%);
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow:
    0 40px 80px rgba(0, 0, 0, 0.5),
    0 0 100px rgba(251, 146, 60, 0.05);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.lens-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}

.lens-modal-header h2 {
  margin: 0 0 6px 0;
  font-family: var(--font-display);
  font-size: 26px;
  color: #fafaf9;
}

.lens-modal-header p {
  margin: 0;
  color: rgba(250, 250, 249, 0.5);
  font-size: 13px;
}

.lens-modal-close {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  color: rgba(250, 250, 249, 0.7);
  cursor: pointer;
  transition: all 0.25s ease;
}

.lens-modal-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fafaf9;
}

.lens-modal-body {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.lens-modal-gallery {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  grid-gap: 20px;
  gap: 20px;
}

.lens-modal-gallery img {
  width: 100%;
  height: 300px;
  object-fit: cover;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.lens-modal-carousel {
  position: relative;
}

.lens-modal-carousel img {
  display: block;
}

.lens-modal-carousel-controls {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 14px;
  pointer-events: none;
}

.carousel-btn {
  pointer-events: auto;
  border: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.6);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: white;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s ease;
}

.carousel-btn:hover {
  background: rgba(0, 0, 0, 0.8);
  border-color: rgba(255, 255, 255, 0.2);
}

.lens-modal-carousel-dots {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 14px;
}

.lens-modal-carousel-dots button {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.2);
  cursor: pointer;
  transition: all 0.25s ease;
}

.lens-modal-carousel-dots button.is-active {
  background: #fb923c;
  box-shadow: 0 0 10px rgba(251, 146, 60, 0.5);
}

.lens-modal-photo-stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.lens-modal-photo-tabs {
  display: flex;
  gap: 8px;
}

.lens-modal-photo-tabs button {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  cursor: pointer;
  color: rgba(250, 250, 249, 0.7);
}

.lens-modal-photo-tabs button.is-active {
  background: rgba(251, 146, 60, 0.2);
  color: #fb923c;
  border-color: rgba(251, 146, 60, 0.4);
}

.lens-modal-user-photos {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.lens-modal-user-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 10px;
  gap: 10px;
}

.lens-modal-user-grid img {
  width: 100%;
  height: 120px;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid rgba(16, 19, 26, 0.08);
}

.lens-modal-user-empty {
  border: 1px dashed rgba(255, 255, 255, 0.2);
  border-radius: 12px;
  padding: 24px;
  text-align: center;
  font-size: 12px;
  color: rgba(250, 250, 249, 0.6);
  grid-column: 1 / -1;
}

.lens-modal-upload {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  width: -moz-fit-content;
  width: fit-content;
  color: rgba(250, 250, 249, 0.8);
}

.lens-modal-upload input {
  display: none;
}

.lens-modal-personal {
  background: rgba(255, 255, 255, 0.04);
  border-radius: 16px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.lens-modal-personal-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.lens-modal-personal-header h3 {
  margin: 0;
  font-size: 16px;
  color: #fafaf9;
}

.lens-modal-personal-header span {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(250, 250, 249, 0.5);
}

.lens-modal-personal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 14px;
  gap: 14px;
}

.lens-modal-personal-actions {
  display: flex;
  justify-content: flex-end;
}

.lens-modal-personal-actions button {
  border: none;
  background: rgba(251, 146, 60, 0.2);
  color: #fb923c;
  border-radius: 10px;
  padding: 8px 16px;
  font-size: 12px;
  cursor: pointer;
}

.lens-modal-personal-actions button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.lens-modal-personal-grid label {
  font-size: 12px;
  color: rgba(250, 250, 249, 0.6);
  display: block;
  margin-bottom: 6px;
}

.lens-modal-notes {
  grid-column: 1 / -1;
}

.lens-modal-personal-grid input,
.lens-modal-personal-grid textarea {
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 8px 10px;
  font-size: 13px;
  font-family: inherit;
  background: rgba(255, 255, 255, 0.06);
  color: #fafaf9;
}

.rating-stars {
  display: flex;
  gap: 4px;
}

.rating-stars button {
  border: none;
  background: transparent;
  font-size: 18px;
  color: rgba(250, 250, 249, 0.2);
  cursor: pointer;
}

.rating-stars button.is-active {
  color: #f4b740;
}

.wishlist-setting {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
}

.wishlist-setting label {
  color: rgba(250, 250, 249, 0.6);
}

.toggle {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 11px;
  cursor: pointer;
  color: rgba(250, 250, 249, 0.8);
}

.toggle.on {
  background: rgba(251, 146, 60, 0.2);
  color: #fb923c;
  border-color: rgba(251, 146, 60, 0.4);
}

.wishlist-share {
  display: flex;
  gap: 8px;
}

.wishlist-share input {
  flex: 1 1;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  padding: 8px 10px;
  font-size: 12px;
  font-family: inherit;
  background: rgba(255, 255, 255, 0.06);
  color: #fafaf9;
}

.wishlist-share button {
  border: none;
  background: rgba(251, 146, 60, 0.2);
  color: #fb923c;
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 12px;
  cursor: pointer;
}

.wishlist-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.wishlist-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255, 255, 255, 0.04);
}

.wishlist-item strong {
  display: block;
  font-size: 13px;
}

.wishlist-item span {
  font-size: 11px;
  color: rgba(250, 250, 249, 0.6);
}

.wishlist-item-controls {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.wishlist-item-controls select {
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  padding: 6px 8px;
  font-size: 11px;
  font-family: inherit;
  background: rgba(255, 255, 255, 0.06);
  color: #fafaf9;
}

.lens-modal-placeholder {
  height: 300px;
  border-radius: 20px;
  background: linear-gradient(145deg, #1c1917, #f97316);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 56px;
  font-weight: 700;
}

.lens-modal-specs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 16px;
  gap: 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  padding: 20px;
  border-radius: 18px;
  align-content: start;
}

.lens-modal-specs>div {
  padding: 12px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 12px;
}

.lens-modal-specs span {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(250, 250, 249, 0.4);
  font-weight: 500;
}

.lens-modal-specs strong {
  display: block;
  margin-top: 6px;
  font-size: 17px;
  color: #fafaf9;
  font-family: var(--font-display);
}

.lens-modal-heritage {
  padding: 20px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.lens-modal-heritage h3 {
  margin: 0 0 16px 0;
  font-size: 17px;
  font-family: var(--font-display);
  color: #fafaf9;
}

.lens-modal-loading,
.lens-modal-error,
.lens-modal-empty {
  margin: 0;
  font-size: 13px;
  color: rgba(250, 250, 249, 0.5);
}

/* Sidebar Panels - Glass Cards */
.collection-panel {
  background: rgba(255, 255, 255, 0.02);
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 20px;
  transition: all 0.3s ease;
}

.collection-panel:hover {
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.08);
}

.collection-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.collection-panel-header h3 {
  margin: 0;
  font-size: 15px;
  font-family: var(--font-display);
  color: #fafaf9;
  font-weight: 600;
}

.collection-panel-header span {
  font-size: 10px;
  color: rgba(250, 250, 249, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 500;
}

.collection-panel-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Featured Lens Panel */
.featured-image {
  height: 120px;
  border-radius: 16px;
  background: linear-gradient(145deg, #1c1917, #f97316);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  font-family: var(--font-display);
  font-weight: 700;
  position: relative;
  overflow: hidden;
}

.featured-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.4) 100%);
}

.featured-info h4 {
  margin: 0 0 6px 0;
  font-size: 15px;
  color: #fafaf9;
}

.featured-info p {
  margin: 0;
  font-size: 12px;
  color: rgba(250, 250, 249, 0.5);
}

.featured-info blockquote {
  margin: 12px 0 0 0;
  padding: 12px;
  padding-left: 14px;
  border-left: 3px solid rgba(251, 146, 60, 0.6);
  background: rgba(251, 146, 60, 0.05);
  border-radius: 0 10px 10px 0;
  font-size: 12px;
  font-style: italic;
  color: rgba(250, 250, 249, 0.7);
}

/* Recent Items Panel */
.recent-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  color: rgba(250, 250, 249, 0.8);
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 10px;
  transition: all 0.25s ease;
}

.recent-item:hover {
  background: rgba(255, 255, 255, 0.04);
}

.recent-item small {
  color: rgba(250, 250, 249, 0.4);
  font-size: 11px;
}

/* Achievements Panel */
.achievements-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 10px;
  gap: 10px;
}

.achievement-badge {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 14px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
  transition: all 0.25s ease;
}

.achievement-badge:hover {
  background: rgba(251, 146, 60, 0.08);
  border-color: rgba(251, 146, 60, 0.2);
}

.achievement-badge span {
  font-size: 24px;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
}

.achievement-badge p {
  margin: 0;
  font-size: 11px;
  color: rgba(250, 250, 249, 0.6);
  font-weight: 500;
}

/* Market Trends Panel */
.market-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.market-grid>div {
  padding: 14px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 12px;
}

.market-grid p {
  margin: 0 0 10px 0;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(250, 250, 249, 0.4);
  font-weight: 600;
}

.market-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: rgba(250, 250, 249, 0.7);
  padding: 8px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.market-item:last-child {
  border-bottom: none;
}

.market-item.hot strong {
  color: #22c55e;
  font-weight: 600;
}

.market-item.cold strong {
  color: #ef4444;
  font-weight: 600;
}

.profile-container {
  max-width: 900px;
  margin: 0 auto;
}

/* Profile Header */
.profile-header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 32px;
  padding: 24px;
  background: var(--panel-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.profile-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
}

.profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-avatar-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--accent) 0%, #ff9f7c 100%);
  color: white;
  font-size: 32px;
  font-weight: 600;
  font-family: var(--font-display);
}

.profile-header-info h1 {
  margin: 0 0 4px 0;
  font-size: 24px;
  font-weight: 600;
  font-family: var(--font-display);
  color: var(--ink);
}

.profile-subtitle {
  margin: 0;
  color: var(--ink-soft);
  font-size: 14px;
}

/* Profile Grid */
.profile-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 24px;
  gap: 24px;
  margin-bottom: 32px;
}

/* Profile Cards */
.profile-card {
  background: var(--panel-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.profile-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--stroke);
  background: rgba(255, 255, 255, 0.5);
}

.profile-card-header svg {
  color: var(--accent);
  flex-shrink: 0;
}

.profile-card-header h2 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  font-family: var(--font-display);
  flex: 1 1;
}

.profile-edit-btn {
  padding: 6px 12px;
  border: none;
  border-radius: 8px;
  background: var(--accent);
  color: white;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}

.profile-edit-btn:hover {
  background: var(--accent-strong);
}

.profile-card-content {
  padding: 20px;
}

/* Profile Info Rows */
.profile-info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--stroke);
}

.profile-info-row:last-child {
  border-bottom: none;
}

.profile-label {
  font-size: 14px;
  color: var(--ink-soft);
}

.profile-value {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  text-align: right;
}

/* Shipping Form */
.shipping-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.shipping-form-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.shipping-form-row label {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-soft);
}

.shipping-form-row input,
.shipping-form-row textarea {
  padding: 10px 14px;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  font-size: 14px;
  font-family: inherit;
  background: white;
  transition: all 0.2s;
}

.shipping-form-row input:focus,
.shipping-form-row textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255, 111, 60, 0.1);
}

.shipping-form-row textarea {
  resize: vertical;
  min-height: 60px;
}

.shipping-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 16px;
  gap: 16px;
}

.shipping-form-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 8px;
}

.btn-primary,
.btn-secondary {
  padding: 10px 20px;
  border: none;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}

.btn-primary {
  background: var(--accent);
  color: white;
}

.btn-primary:hover:not(:disabled) {
  background: var(--accent-strong);
}

.btn-primary:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.btn-secondary {
  background: var(--stroke);
  color: var(--ink);
}

.btn-secondary:hover:not(:disabled) {
  background: rgba(16, 19, 26, 0.12);
}

/* Shipping Display */
.shipping-display {
  line-height: 1.6;
}

.shipping-name {
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 4px 0;
}

.shipping-phone {
  color: var(--ink-soft);
  font-size: 14px;
  margin: 0 0 8px 0;
}

.shipping-address-line,
.shipping-location,
.shipping-country {
  color: var(--ink);
  font-size: 14px;
  margin: 0;
}

.shipping-country {
  color: var(--ink-soft);
  margin-top: 4px;
}

/* Shipping Empty */
.shipping-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 24px 0;
}

.shipping-empty svg {
  color: var(--ink-soft);
  opacity: 0.4;
  margin-bottom: 16px;
}

.shipping-empty-title {
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 4px 0;
}

.shipping-empty-hint {
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0 0 16px 0;
}

/* Orders Section */
.profile-orders-section {
  background: var(--panel-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.profile-memory-section {
  margin-top: 24px;
  background: var(--panel-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.memory-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.memory-item {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid var(--stroke);
}

.memory-category {
  margin: 0;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
}

.memory-value {
  margin: 4px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}

.memory-confidence {
  margin: 0;
  font-size: 12px;
  color: var(--ink-soft);
}

.memory-quote {
  margin: 0;
  font-size: 12px;
  color: var(--ink-soft);
}

.memory-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-end;
}

.memory-edit {
  display: flex;
  gap: 8px;
  align-items: center;
}

.memory-edit input {
  border-radius: 8px;
  border: 1px solid var(--stroke);
  padding: 6px 8px;
  font-size: 12px;
  font-family: inherit;
}

.memory-edit button {
  border: none;
  background: rgba(255, 111, 60, 0.12);
  color: var(--accent);
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 11px;
  cursor: pointer;
}

.memory-empty {
  margin: 0;
  color: var(--ink-soft);
  font-size: 14px;
}

.profile-section-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--stroke);
  background: rgba(255, 255, 255, 0.5);
}

.profile-section-header svg {
  color: var(--accent);
}

.profile-section-header h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  font-family: var(--font-display);
}

/* Orders Empty */
.orders-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 48px 24px;
}

.orders-empty svg {
  color: var(--ink-soft);
  opacity: 0.4;
  margin-bottom: 16px;
}

.orders-empty-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 4px 0;
}

.orders-empty-hint {
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0 0 20px 0;
}

/* Orders List */
.orders-list {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Order Card */
.order-card {
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding: 16px;
  transition: all 0.2s;
}

.order-card:hover {
  border-color: rgba(255, 111, 60, 0.3);
  box-shadow: 0 4px 12px rgba(16, 19, 26, 0.06);
}

.order-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.order-number {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.order-label {
  font-size: 12px;
  color: var(--ink-soft);
}

.order-value {
  font-size: 16px;
  font-weight: 600;
  font-family: var(--font-display);
  color: var(--ink);
}

.order-status {
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 500;
}

.status-pending {
  background: rgba(255, 193, 7, 0.15);
  color: #b38600;
}

.status-paid {
  background: rgba(76, 175, 80, 0.15);
  color: #2e7d32;
}

.status-shipped {
  background: rgba(33, 150, 243, 0.15);
  color: #1565c0;
}

.status-delivered {
  background: rgba(76, 175, 80, 0.2);
  color: #1b5e20;
}

.status-cancelled {
  background: rgba(244, 67, 54, 0.15);
  color: #c62828;
}

.order-meta {
  display: flex;
  gap: 24px;
  padding: 12px 0;
  border-top: 1px solid var(--stroke);
  border-bottom: 1px solid var(--stroke);
  margin-bottom: 12px;
}

.order-meta-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.order-meta-label {
  font-size: 12px;
  color: var(--ink-soft);
}

.order-meta-value {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
}

.order-total {
  color: var(--accent);
  font-weight: 600;
}

.order-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.order-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
}

.order-item-name {
  flex: 1 1;
  color: var(--ink);
}

.order-item-qty {
  color: var(--ink-soft);
}

.order-item-price {
  font-weight: 500;
  color: var(--ink);
}

/* Profile Loading */
.profile-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  gap: 16px;
}

.profile-loading-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--stroke);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

.profile-loading p {
  color: var(--ink-soft);
  font-size: 14px;
}

/* Profile Error */
.profile-error {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  text-align: center;
  padding: 24px;
}

.profile-error-icon svg {
  color: var(--accent);
  opacity: 0.6;
  margin-bottom: 16px;
}

.profile-error h2 {
  margin: 0 0 8px 0;
  font-size: 20px;
  color: var(--ink);
}

.profile-error p {
  margin: 0 0 20px 0;
  color: var(--ink-soft);
}

.profile-retry-btn {
  padding: 10px 24px;
  border: none;
  border-radius: 10px;
  background: var(--accent);
  color: white;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}

.profile-retry-btn:hover {
  background: var(--accent-strong);
}

/* Profile Not Logged In */
.profile-not-logged-in {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  text-align: center;
  padding: 24px;
}

.profile-lock-icon svg {
  color: var(--ink-soft);
  opacity: 0.4;
  margin-bottom: 16px;
}

.profile-not-logged-in h2 {
  margin: 0 0 20px 0;
  font-size: 20px;
  color: var(--ink);
}

.profile-login-btn {
  padding: 12px 32px;
  border: none;
  border-radius: 12px;
  background: var(--accent);
  color: white;
  font-size: 16px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}

.profile-login-btn:hover {
  background: var(--accent-strong);
  transform: translateY(-1px);
}

/* ===================== */
/* Settings Tab - Dark Theme */
/* ===================== */

.settings-layout {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 32px;
  background: #0c0a09;
  min-height: calc(100vh - 200px);
}

.settings-layout .profile-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 24px;
  gap: 24px;
  margin-bottom: 0;
}

.settings-layout .profile-card {
  background: rgba(255, 255, 255, 0.02);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 20px;
  box-shadow: none;
}

.settings-layout .profile-card-header {
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding: 20px 24px;
}

.settings-layout .profile-card-header svg {
  color: #fb923c;
}

.settings-layout .profile-card-header h2 {
  color: #fafaf9;
  font-size: 16px;
}

.settings-layout .profile-edit-btn {
  background: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
  border-radius: 10px;
  font-size: 12px;
  padding: 8px 14px;
  box-shadow: 0 4px 12px rgba(249, 115, 22, 0.25);
}

.settings-layout .profile-edit-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(249, 115, 22, 0.35);
}

.settings-layout .profile-card-content {
  padding: 24px;
}

.settings-layout .profile-info-row {
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  padding: 14px 0;
}

.settings-layout .profile-info-row:last-child {
  border-bottom: none;
}

.settings-layout .profile-label {
  color: rgba(250, 250, 249, 0.5);
  font-size: 13px;
}

.settings-layout .profile-value {
  color: #fafaf9;
  font-size: 14px;
}

/* Settings Form Inputs - Dark */
.settings-layout .shipping-form-row label {
  color: rgba(250, 250, 249, 0.5);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.settings-layout .shipping-form-row input,
.settings-layout .shipping-form-row textarea {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  color: #fafaf9;
  padding: 12px 16px;
  transition: all 0.25s ease;
}

.settings-layout .shipping-form-row input::placeholder,
.settings-layout .shipping-form-row textarea::placeholder {
  color: rgba(250, 250, 249, 0.3);
}

.settings-layout .shipping-form-row input:focus,
.settings-layout .shipping-form-row textarea:focus {
  outline: none;
  border-color: rgba(251, 146, 60, 0.4);
  background: rgba(255, 255, 255, 0.05);
  box-shadow: 0 0 0 3px rgba(251, 146, 60, 0.1);
}

/* Shipping Display - Dark */
.settings-layout .shipping-display {
  color: rgba(250, 250, 249, 0.8);
}

.settings-layout .shipping-name {
  color: #fafaf9;
  font-weight: 600;
}

.settings-layout .shipping-phone {
  color: rgba(250, 250, 249, 0.5);
}

.settings-layout .shipping-address-line,
.settings-layout .shipping-location {
  color: rgba(250, 250, 249, 0.8);
}

.settings-layout .shipping-country {
  color: rgba(250, 250, 249, 0.4);
}

/* Shipping Empty - Dark */
.settings-layout .shipping-empty {
  padding: 32px 24px;
}

.settings-layout .shipping-empty svg {
  color: rgba(250, 250, 249, 0.3);
}

.settings-layout .shipping-empty-title {
  color: #fafaf9;
}

.settings-layout .shipping-empty-hint {
  color: rgba(250, 250, 249, 0.5);
}

/* Button styles in settings */
.settings-layout .btn-primary {
  background: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
  border: none;
  box-shadow: 0 4px 12px rgba(249, 115, 22, 0.25);
  border-radius: 12px;
}

.settings-layout .btn-primary:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(249, 115, 22, 0.35);
}

.settings-layout .btn-secondary {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(250, 250, 249, 0.9);
  border-radius: 12px;
}

.settings-layout .btn-secondary:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

/* Orders Section - Dark */
.settings-layout .profile-orders-section {
  background: rgba(255, 255, 255, 0.02);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 20px;
  box-shadow: none;
}

.settings-layout .profile-section-header {
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding: 20px 24px;
}

.settings-layout .profile-section-header svg {
  color: #fb923c;
}

.settings-layout .profile-section-header h2 {
  color: #fafaf9;
}

/* Orders Empty - Dark */
.settings-layout .orders-empty {
  padding: 64px 32px;
}

.settings-layout .orders-empty svg {
  color: rgba(250, 250, 249, 0.2);
}

.settings-layout .orders-empty-title {
  color: #fafaf9;
  font-size: 20px;
}

.settings-layout .orders-empty-hint {
  color: rgba(250, 250, 249, 0.5);
}

/* Orders List - Dark */
.settings-layout .orders-list {
  padding: 24px;
}

/* Order Card - Dark Glass */
.settings-layout .order-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  padding: 20px;
  transition: all 0.25s ease;
}

.settings-layout .order-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(251, 146, 60, 0.2);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.settings-layout .order-label {
  color: rgba(250, 250, 249, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 11px;
}

.settings-layout .order-value {
  color: #fafaf9;
}

/* Order Status Pills - Dark */
.settings-layout .status-pending {
  background: rgba(251, 191, 36, 0.15);
  color: #fbbf24;
  border: 1px solid rgba(251, 191, 36, 0.2);
}

.settings-layout .status-paid {
  background: rgba(34, 197, 94, 0.15);
  color: #22c55e;
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.settings-layout .status-shipped {
  background: rgba(59, 130, 246, 0.15);
  color: #3b82f6;
  border: 1px solid rgba(59, 130, 246, 0.2);
}

.settings-layout .status-delivered {
  background: rgba(34, 197, 94, 0.2);
  color: #4ade80;
  border: 1px solid rgba(34, 197, 94, 0.25);
}

.settings-layout .status-cancelled {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
  border: 1px solid rgba(239, 68, 68, 0.2);
}

.settings-layout .order-meta {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.settings-layout .order-meta-label {
  color: rgba(250, 250, 249, 0.4);
}

.settings-layout .order-meta-value {
  color: #fafaf9;
}

.settings-layout .order-total {
  color: #fb923c;
}

.settings-layout .order-item-name {
  color: rgba(250, 250, 249, 0.9);
}

.settings-layout .order-item-qty {
  color: rgba(250, 250, 249, 0.4);
}

.settings-layout .order-item-price {
  color: #fafaf9;
}

/* Profile Loading/Error States - Dark */
.profile-page .profile-loading,
.profile-page .profile-error,
.profile-page .profile-not-logged-in {
  background: #0c0a09;
  min-height: calc(100vh - 100px);
}

.profile-page .profile-loading p {
  color: rgba(250, 250, 249, 0.5);
}

.profile-page .profile-loading-spinner {
  border: 3px solid rgba(255, 255, 255, 0.1);
  border-top-color: #fb923c;
}

.profile-page .profile-error h2,
.profile-page .profile-not-logged-in h2 {
  color: #fafaf9;
}

.profile-page .profile-error p {
  color: rgba(250, 250, 249, 0.5);
}

.profile-page .profile-retry-btn,
.profile-page .profile-login-btn {
  background: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(249, 115, 22, 0.3);
}

.profile-page .profile-retry-btn:hover,
.profile-page .profile-login-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(249, 115, 22, 0.4);
}

.profile-page .profile-lock-icon svg,
.profile-page .profile-error-icon svg {
  color: rgba(250, 250, 249, 0.3);
}

/* Profile Responsive */
@media (max-width: 768px) {
  .profile-page {
    padding: 0;
  }

  .profile-header {
    flex-direction: column;
    text-align: center;
    padding: 20px;
  }

  .profile-grid {
    grid-template-columns: 1fr;
  }

  .collectible-hero {
    flex-direction: column;
    align-items: flex-start;
  }

  .collectible-hero-actions {
    width: 100%;
  }

  .collectible-hero-actions .btn-primary,
  .collectible-hero-actions .btn-secondary {
    flex: 1 1;
  }

  .collection-layout {
    grid-template-columns: 1fr;
  }

  .collection-stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .collection-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .collection-search {
    flex-direction: column;
  }

  .lens-modal {
    padding: 20px;
  }

  .lens-modal-gallery {
    grid-template-columns: 1fr;
  }

  .lens-modal-personal-grid {
    grid-template-columns: 1fr;
  }

  .lens-modal-user-grid {
    grid-template-columns: 1fr;
  }

  .wishlist-share {
    flex-direction: column;
  }

  .wishlist-item-controls {
    flex-direction: column;
  }

  .shipping-form-grid {
    grid-template-columns: 1fr;
  }

  .order-meta {
    flex-wrap: wrap;
    gap: 16px;
  }

  .order-meta-item {
    min-width: calc(50% - 8px);
  }

  .order-item {
    flex-wrap: wrap;
  }

  .order-item-name {
    width: 100%;
    margin-bottom: 4px;
  }

  /* Settings Layout - Mobile */
  .settings-layout {
    padding: 16px;
    gap: 16px;
  }

  .settings-layout .profile-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .settings-layout .profile-card-header {
    padding: 16px 20px;
  }

  .settings-layout .profile-card-content {
    padding: 20px;
  }

  .settings-layout .orders-empty {
    padding: 48px 20px;
  }

  .settings-layout .orders-list {
    padding: 16px;
  }

  /* Hero Mobile Adjustments */
  .collectible-hero {
    padding: 32px 20px;
  }

  .collectible-hero-main {
    flex-direction: column;
    text-align: center;
    gap: 20px;
  }

  .collectible-hero-text {
    align-items: center;
  }

  .collectible-hero-name {
    font-size: 24px;
  }

  .collectible-hero-stats {
    justify-content: center;
  }

  /* Collection Main - Mobile */
  .collection-main {
    padding: 20px 16px;
  }

  .collection-sidebar {
    padding: 20px 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
  }

  /* Tabs - Mobile */
  .collectible-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .collectible-tabs button {
    padding: 14px 24px;
    white-space: nowrap;
  }
}
