  *,
  *::before,
  *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box
  }

  :root {
    /* Silver — primary brand (matches logo) */
    --s: #C8C8C8;
    /* main silver */
    --s2: #E4E4E4;
    /* light silver */
    --s3: #888888;
    /* dark silver */
    /* Silver — accent / CTA */
    --g: #C8C8C8;
    /* warm silver */
    --g2: #E4E4E4;
    /* light silver */
    --g3: #888888;
    /* dark silver */
    /* Base */
    --cream: #F5F2EC;
    --ink: #09090B;
    --deep: #0D0D0F;
    --panel: #131316;
    --card: #1C1C20;
    --muted: rgba(245, 242, 236, 0.42);
    --border: rgba(200, 200, 200, 0.13);
  }

  html {
    scroll-behavior: smooth
  }

  body {
    background: var(--ink);
    color: var(--cream);
    font-family: 'Josefin Sans', sans-serif;
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
    position: relative;
  }

  /* Logo watermark tiled background */
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image: url("data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wCEAAYGBgYHBgcICAcKCwoLCg8ODAwODxYQERAREBYiFRkVFRkVIh4kHhweJB42KiYmKjY+NDI0PkxERExfWl98fKcBBgYGBgcGBwgIBwoLCgsKDw4MDA4PFhAREBEQFiIVGRUVGRUiHiQeHB4kHjYqJiYqNj40MjQ+TERETF9aX3x8p//CABEIAfQB9AMBIgACEQEDEQH/xAAuAAEAAgMBAAAAAAAAAAAAAAAABAUBAgMGAQEBAQAAAAAAAAAAAAAAAAAAAQL/2gAMAwEAAhADEAAAAvKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA3sYlnEul9V5orRQAAAAAAAAAAAAAAAAAAAAAAAAAAACzrBv3iyoufP3tEdOBQ2NQAAAAAAAAAAAAAAAAAAAAAAJmNzsqxZV+LErSaRrmy7Zc+lZQHpseXV6iuqrYhSLarKoUAAAAAAAAAAAAAAAAAAAAANizqrSrBII82ZAh6WPJN4M7y0RRoABbYrLGKwUAAAAAAAAAAAAAAAAAAAANjUFtU2cQj2NcPUQ6e3iz303jTyPpvM0FAAOvIAAAAAAAAAAAAAAAAAAAAAJEfYxibCN7am2JUOylxRegj5LXFd0MUHo4hTt9KAAAAAAAAAAAAAAAAAAAAAAAAdOe5J0SCuS4gB33ii1q/Sx4qOs21IlD2tCgFAAAAAAAAAAAAAAAAAAAAAAAAS8w5ht3xEjEed2qrS4hO9D5CdFtIgyI61NrS1wjW1SDpWvWzrDgAAAAAAAAAAAAAAAAAAAAABnA6zI8k6I/CJmkYac5csq9ptdXoYtVtFtzxsdtqqKd+BQAAAAAAAAAAAAAAAAAAAAAAAEmVWC4U6LGDoAp055M6gAAAOpyej4xSazI1aAAAAAAAAAAAAO/QiJghpmhGZmEJOEFP5kQkEdY5K1ZorHfnWiVzOK2zFQuMlMs60wt+hSLsUi7pjWTJkFvwr9Sq0toZFdd6jgGTDvwAAAAAAAGcbE7hvDJKMJOvAS99cGM8h1kQ5RGmwpsRs8h1cslnVWtUTpHDYjrDJXrAVfbTQmx7fkVqzFZXXVITO28sgJ2pBj2cEzYV/M718yTVVtnBNgT4AAAAAAAA21EyHY7FYtMlUteJpIjciYrRZ9qawK+3rJ5ttUC3kUG0T4tlWk+ptdyuzf7Hnnockbz17AI+/pMnmnpRBp/R+WOm9pOPOPRaFBy9DVmnPfmR+nNVpGiTTMGbCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP/EAAL/2gAMAwEAAgADAAAAIQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAKiAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFpoAAAAAAAAAAAAAAAAAAAAAAAAGAPBJywEvgAAAAAAAAAAAAAAAAAAAAABMAFhT4AAHgAAAAAAAAAAAAAAAAAAAABECFAi4QAAEAAAAAAAAAAAAAAAAAAAAAAKEHhnZAAAAAAAAAAAAAAAAAAAAAAAAAFHAEANHJgAAAAAAAAAAAAAAAAAAAAAAAAAKkAElwChFAAAAAAAAAAAAAAAAAAAAAAEJPlrhBsngAAAAAAAAAAAAAAAAAAAAAAAEAMggEAAAABAqAAAAAAAAAAAABACCBAACAjADihigjhhSiAAAAAAAAAAAIEILLAGpuvpEDFvMPiIKpkHKAAAAAAABICDLEJMIMtlmuJgAAjJHnkCKAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP/EAAL/2gAMAwEAAgADAAAAEPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPAffPPPPPPPPPPPPPPPPPPPPPPPPPPPPLHiPPPPPPPPPPPPPPPPPPPPPPPPPIDFOCpj9RfPPPPPPPPPPPPPPPPPPPPPOJOLlI3PPDvPPPPPPPPPPPPPPPPPPPPPPHONIXvPPPPPPPPPPPPPPPPPPPPPPPPOPCCtNN9PPPPPPPPPPPPPPPPPPPPPPPPLNPPPNw+fPPPPPPPPPPPPPPPPPPPPPPPPKHrNCfiVvIPPPPPPPPPPPPPPPPPPPPPPLJDpvqLbYHPPPPPPPPPPPPPPPPPPPPPPPPDPvvKHPPPOOVPPPPPPPPPPPPONMPPPPNNtMP8esMctEPuPPPPPPPPPPOLLDMDEJgllp632Zca86+inKPPPPPPPPKNPNCPDCLPsu4T+YR/Jy2prHNPPPPPPPPPPPPPLPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPP/EACQRAAICAQQBBAMAAAAAAAAAAAABAhFREiExQEEQIkKAMFCB/9oACAECAQE/APpg26INt/oI95zfgUG92aIlNcCd9rkk7IK33qpDIcd5tMqJFrjv6knRKVOmthbccd6UbHwR8oXHb/pvkteijTs93gSfl9ukJJfg1Lq2WvXUsmqORNM1Rya45E0xyiJQyWupsbGT4lxwXA+OxcK4LhgVeBuF7lwE0eepQuDhGpYNSwLZM1xwa1gjy2OSvgUlgtHn6kf/xAAfEQADAAICAgMAAAAAAAAAAAAAAREQQCFQQYACEjH/2gAIAQMBAT8A9MEP8776jZWcbiQ3vo+W+qNPv05h9BTjpY9mMjzHmvY8kZGeTk5xGR7MZHiMjxGR+pX/xAA/EAABAwIBBgwFAgUEAwAAAAABAAIDBBESBRQVITFTEBMiMkFRUmFicYGRIDNCUKE0QCMwQ4KxJGOgwXJzkv/aAAgBAQABPwL/AIRxjeGtcW6jsKpqWJ9PjcNfGAIUNA4uAbrG3WVXwshqC1gsLD74+qlfCyI7AqL9IP8A3BBoF7Dasq/qz/4j73k9tMeM43bbp6k/DjOHZ0KmbJI7AJMNgXeybS1DomuFW/W26e97zdzrlGVnECPiuVfnffKcVDXXZGTdpGzrTaqsbGG5odQsnRyN5zCPgwuwh1tX2+GlLtbtQXGUsWoC6zyA/wBNGGnnH8I2d1J7HMcWuGvhjikldZjbqHJTdsrr9wUdPDHzYwE+RkYu9wCdlOkH1E+iGVKQ7SR6IwUVQNQafJS5Lt8t/oUKKovYtt3qsbghjb1fbqaLEcR2BVM+vA314QSDcJ9qmmx/WzbwUtG6c3OpiiiZE3CwW4KzKAi5Eet3SepPkfI67nXPC1zmm4NiqbKF+TL/APSKr+Y3z+3fKg9PhoT/ABHN7TSqWnM8lugbU0BoAGxBV9VxMeFvOd8dFUXHFu9FX8xvn9tZrc3zVV8r14aeDjn26OlGgitqJuo2uikffa0f5VNCIYg3p6eGsl42oeejYPjY4tcHDoVYbxMP26YY4Dw0EjRiYenga5k1VydjNp6+GZ2CGR3U3+S6Vzo2sPR9rw8nFw0smJmHqVRCY3dx4TJIRYuNlk1toi7rPDlA2pJPT7pBZ2Jh6UQQSOBjyx1wmOjnZ/0paR7NbdY4aD9M314OMjG14WUZGGmsHA6x90a4tIIU7MbRI3ha4tNwVFXD6x6rBTzjoKOTmHY8hChlDcIqNXktHXHKmcVo2m7/AHWjqM7P8qXJLhrjffuKexzHYXCx+5BuJh6wqaS3IKqIcBuNnwipnGyQrPKneKVlbgDxIXC3Qi5x2klMp5pG4mNuFFWVMB5x8igafKERGx4/CmifDIWO2j7jG/A4FSxW5bdigmDxgft/ypqYt1t2fFRycZAw+hVXQCTlx6ndXWslPLXyRHzU9LFOLOGvrUkc1HMOsbD1qoa2tpBM3nt+5QTW5Dtimpy3lM2KGrtqf7p1PFKMTCn00rPpv8FFU8S+x5p2ova1uI7OtVMPKbUx85u3vCfI/i2zR6x0jrCnjZV03J82lZLmwT8Wdj/8qri4qokZ0X1fA1pcbBTRCPCOm2v7bDU4dTtifTxyjE0oxTwm49wmV0g2gFZ1TP58alNJ9Adw01a+Hku5TOpRVMcfNN4j0dLFDIyObi7jA/WxRjiKgs+iTW3uKq28RWkjrDgsrj+LG7rbwxxPkNmhMiZTsuT5lTy8Y7u+2gXQdLEekJld22rFRy7bX9lmUDua9aNd0SBHJ03W1SROjNjb34G4r8najjadZ1hRVOc0/wDus1+yyqQ/iJB9TVVxmbMo27SwrRMvbamZMibz3F34Us8EAwj2CmnfKdezq+3x1BbqcMTUIqWbmmxTqCToIKzecfQV/qP9z8rDUu1WemUNS76LeaGTmMGKeWwUtVG1uCnZhHa6eBrnNN2mxTpHOaxp+m9vVS1Ihqo+Ti4tlk7K8h2RgKSsqJNr/b7myqmZ9SblE9Ma0lH2CjlRvRGU/KU55tmp8j3m7nE/BFYOxHo1pzi5xJ2n+YGOdsH3yKGWY2Y26jpomNAzVx7zZVFKx7ORTOa7o2LC7HxJGvoF7BpT+edQ9PvdLO6CUOHkVx8Ntb2+6mqGNYXNe33Ujy97nHp/csgc4X2LNfEs08azTxrNPGpKfA2+JNaXGwWZntrMvH+FmXj/AAsy8f4T6R7RcG/BDTvl7gtHnefhaPO8/C0cd5+Fo07z8KankhOvZ1qNmN7W9aqaYwYeVe6hhfM6zQtFO3o9lok778LRJ334WiDvvwp8mmGJz+MvbuQBJsEzJEhHKkA7tq0Md9+FoZ2+HstDO3w9loY778JzcLnN6iqXJ5qI8fGW19S0Od9+Fog778LRJ334Wizvfwqmm4jDyr3UMRlfhCmp3xHrHX8AFyApISwXv+wG0KaQxgWWcydQWdSdQWdSdQWdSdyfO97bGypOc5S1D2SECyzuXuWeS9yzyXuVPUue/C6yqWYZT361A7BSYh3rPpvCs+n8Kz+fwrP5+5YhU0jiQqb58fmsqbYvVUADKUv8/wALSVR4fZaSqfD7LSdT4fZaTqvD7KWunlYWOtYrJTAagnqCqspTMncxlrBaVqvD7LStV4fZaVqvD7LStX4fZE3JPWoK6eBmFlrLStV4fZaUqfD7LSdT4fZaRqPD7KaokmtitqVB8/8AtRmj4x0blPSW1x+3Cznt81VfLHn+wbzgqr6fipNrlNDI6RxDVm83YWbzdhZvN2FSwPa/E4KqcHTFRAmisNutZrP2FmtRu1mtRuys0qN2mNzekdi2qm+fH5rKm2L1WTpWlroj6LRtP3rRlP4loun8S0XT9blWUJgGIG7VQTiGcE7DqKmoKed/GG9z1LRNN1uWiabrctE03W5VGSbMLoiSergo8nsnixl5GtaIi3jlomHtuWi4u25aMj7ZVXTCAts691QfO/tVX+oeoaot1O1hSRRzDEPdPjcw2KZz2+aqvljz/YN5wVVsb8VJtcnVLGOLSCs8j6nLPI+y5Csj1aip3PEV2cFO/BSh3VdZ/H2XLSEfZctIR9hygqmTEgaisoOlxhp5vQqX9RH5rKm2L14BUzj+o5Z1Ub1yzqo3rlnVTvXLG6XJhc/bh4GTzMFmyOCzup3rlndTvnLO6nfOWS6iaQyNeSQOlVQAqZQO0mTzRizJCAs7qd873Wd1O9d7rOqjeuWdVG8KfI9/OddUPzv7VV/qH8EcjozqTZI5hb8J0BY4EaxdVXMHn+xa5kjRey4uLshYIuy1YIuy1cXF2Qp2xiM2AVJznKo+c74KWf6HeilwYzg2Jn6E+vwNcWuDhtClmhmpbu2/9qm+fH5rKZF4vVUEMD4iXtBN1m1Lu2rNaXdsWa0m7Ys1o92xV9TE2HiYyPToWT2RvqLPAIwlZpR7pizSj3TFmlHumLNKPdMUktLSRuw4R3BOcXOLjtKydBTvgu9jSbrNaPdMWa0m7Ys2pd2xZvTbtqr442GPAANqofnf2qq+e/4Iqnof7qpIwjz/AOFt/8QAKxAAAgECAwgCAwEBAQAAAAAAAAERITFBUWEQUHGBobHw8SCRwdHhQDCg/9oACAEBAAE/If8AxHOaLnhWci+Ek/dsIqRUjNEzvxyP5x0kZx/aGTITqbSvvwFjvpBVltzqd4JmkUcQlLaIEr2cxlBEk3Ou/GvGwLBY6bKuR1ElHwamKlnu9LywdKWWSkpE2+kNDWWAAm2cRhaOgX2IulEMLqyz8IxQ+LMOz1p4fQczYFlLUoEpMUbu5enEe2ZRXZ7VpjTVmMxDvlstSHfPgIqKCHri5IHB52L2oLyMUNZP4ftvCtKeHU/iia6JGCF6LqhFCWw5TMrRZl/k6eqr9N3KiSeKHbbWVEJcNvAzEZqhLjQjjiNqIQ+RofIXzuuNItTi92ptNNFMXhPa1YSbSiyKCUJzGAhGuA/+NkC17rdFM2ntVKdewkKWVtlNZJPEqBCGVV4dd6JJLKcUPZdbES+iMtcchOfk1t6nuJSu4G5CPMnzMJ70uFITkiu1EhPMsOUNUsVcnu8E0CyewlUu1CTdlYS5FU/pTqNzaMHvKZpVejFtgOxROvp8E2nKcM/sk1/0iTtywNSdZxyOjqnWCCyJXNqF138CRY6m8eovA17rwJOZKik89vyRiiX0EqlYmAUSW6FqrnA7Y0VKiouyCCaNV3W8lZlaSUqZMjMaEaCeasPrkzXwr722osM15NSNTiIiww89k1J+004oc7LI0EMKiXA6/BfXLY5nmo27XRr5sikA3irMrAD9Pp/MyMKlfme2kEmPArvnhwI3dV8JxR+qYLowt0jUTFX89tfjN5D4hI19Ki27WNCuUsOFzUZM1VGNVzkeOOQnZy4wMn0keyZaskDqqBk8GJestdXkGT9H9Ccy/EIz1FQYfQoMksBMG7yvhBlU0oR/WDf7eyY2zg5O5zQRo5SH6cKHjbFtxFmW+gHBCBlrB3rpMOFlRvJNpyi2SWTEYi5MXqxRX2rEsJ1CTI1+EDY9QzKWS/8Apel0b+t5S4jD/k8zqUuqXclxcZP5HDOJNFzqOQmmuyBdR5olbWUy33GZWg7QxQ6rRB4rCmGLubS/9K9KDJ+pL0JehL0GPrRoIKJbFkPokUimT+hHZKtODFmgGlGlGjFIarCtsSiRqrSvhFjm3PBCAaI6bzxNF54kVdGlF3AtIluyFdsdA0e2Uun88SskyL6ISW1FRp/PE0vniNWDzxHlS91d/hFhLclSWysvgNYHAt1ax/gSUakBlLeJ6k9CehNH6jQqGgqkyQmaCzNL6mh9TR+pjIKhF1agMbcSbqeJHkR4EedCqBw/tZbP6H8RA1Vy+LI6H+Y6EMzp8xGqtiqmfg3drE97dpfMkFWmqn4sxY5fGRCzLnEPUJ0vZ4lVa80GmnD2dAOg9v8AB1JZz/Lp0TUk47GoNQa4ojwqDRWFB+TLKC5mr6Gs6HkI132hsrY554bP6H8SOvRnJW/c8jNX7HuBOr+NUMJhYWAC7XPYntT3IpRjHjsvNRQjzkeEh+qGeiWVb6F3iO07EPx3FEpVOCESeZ0A6D2/wdSXOr+XTomIVkeMjzEPNGrUdOY9NiGilfkF6o8ZHmIXU0YPEhFF+rYfh8BNpymIoX3HvD3h7ouFkrwd9kMBlJ7896e9FtUTTYFpSZp2ZPbo3t9hw80LSX+I7Ttslj8VmSEq5i2euQ1H/BVBOTPFMRvqEeqRP+seS7lWHjKg7Ht8FRPxM4m0GUM4d3wfjDJQyujJiHSmLkDmgzCM7PW1iK6Mo8CGGuB7A9VtpYUsfOZeUJfMe5x32Q/4Q/4QzakIpQMk0vEOnFp22ptOUSQR9aamrl/4tv/EACsQAQACAQIEBQUBAQEBAAAAAAEAESExQRBRYdFQcZHw8SCBobHhQDDBoP/aAAgBAQABPxD/AOI67VtxijTLgGzCUyJDsFWk2NdACWSc3xw2Lu1nk9I9nJYm6xSBXN8c+UbNAwG5GBJ90aXVLwZPYKMN4LIKXzI7dQL7aIliFxbxxFOgNCFRPsEbspekMUO6txf0KAHTZU8PKK7W5jgMvMebLFHvVwQVgNVg/ZiYG0jxI751odVhab3wQJFFuWfVnWopEdRMa75hb5kxEitbag46bd0iSHcTD0ZmjAD5HhxoWbDnFGvEG7in9rBpJWgB9xwGWZjf0wQk+q9WbJWa8andZqRqS+OijhKSZ9ziViWbmHw+la4ON3f7MVVVtfoxtMOqFworyv8AxOrBBlA0AmiVEzRb70KpVVW1fqyAnaOXcfbw5BOsG+SwF+nFSY7cDZ8YbZCF6qGl0jzuAALHVLj5DPJmH69BAiaXBp6eGshSIj1IjNAv24kaQru6VBLFAMrDVD6QP2HHc1RCf+JnD4WC1il3sJScahk6rnKLIrfLpwFERpIeDN0DuVPH1ohXrHxQPRpvtuHWEnS08H+r8hFw29bVRoL0IIiiUmpwNdf92AbAc1oluFyTFzpiBaPFGYy3CAto13OK9j0Ewq77cRtKXISpKTW1gIa2fDP1D089sKyk/XRLgvOyWkwYIUa3n/Eq0JsOde1Ucrlvz8ol0V9f0GkA2I0kPAQFZT9oe5/1DhZooAXoREUDRb9pWbkmWPlrLT3A395Ifcvm3Md4/DHAdE8RbZDA5qPR72jlwaBp0B3l+zeN/q3g0x1whRBL0eywl2okpMcIR0MWJuw2QAXsZ7/7niRdl41kHSLWtSusMS3Y1p5keLfVT1I0vYc8RFE42OdhyPaNhJoyB0XSKcNfti6mk2PPu/II2O1k2O0XxCUtolWH2B0+hPeiJmQFsHw0y1s62KcjYzeYRORPMGUAZ64tpeaoy+0a/dOOIDE1Ow6R2y7K1npqyoOSSqLM1FxYe2UcY5QA5MkmiprebiTfl0BzWPeVzfohHWtOd8NvQcgtXALYdkwxQLHX/wDGGYXVeVj1JWbrQoZzF6pbI89aKh+bjV3HAFlvRrjtGyCZt8aMSTQj3zL8xhJbI9DR3jYPVNg7EMfpyyvAtQgmAjSdtdGjoeHmTbmZPK4QoTUNJ9mXKf64MakzfcQ5YCrUXIvrFCmHYCVCX22wb9otPouThoPRIil43kK0gJWcXUeURaLq5sR3NIMVVV8RAIiaJKs6G3HAg3aWB78ZLOjCNupgt+Z1m27+hau9jmmjHNl44U6v/TyigbavEt71XXX/AJKLpgoH3EThIWFWa9QZKeQkAm1TsjUssR3qyr5N42srmQooOTnuF9riINt2+5KGr9H+lADRLlZ0fv5zovfznRe/nOm9/OPMlBWGsScqgizIe/WHIe3nOl9vOD7fbzhDDJAprhUUimR/W957r3gvu/ucn13eAC/QtGKAWdhdSqmEVgjPsmWwHWPMk+/OH9F3hwE8ZZchzUc0T+8Ayqxv3Mh0ny/vPmvefPe/B5nLL/nao/I2v2Yy54ZFQ+87wKFDEwYTNBSNgmGbdCY+hDGkvUxkgu1X+A+eAloxBQUoJ8g7z5F3nzrvPm3eFkpNCOIppkQ+8aZcqiug7M+Td58u7z5l3iY7WMxptBrFAHnKCg1ZYpAO3qzpR6cerMQQXo234/GT2jnAKV16w2qVOUdfhB1p4a4pS4bhI2u+fCZlJt5TrR6k+rwStrbfOVsSZjrrmdSK8F/6ReSA2Iwo9h5kP4GhqFCGor1O6EAImo8Pd+c925v8H4mfn/Xwp11ETYT50nz5PkyPwFArm3fEB0olzepRNPzLU+Xj5GPnoF95+YSU2wOjiCfjJ7xzhmwqqbdRFUiTlJzeKXSY2CUpest1InK9GJqArwamGHFMSipG3bdHgnaVRNoh2YS7cH09ODaemQtWG0CsJ7XzJ7/phVvYgKjMeY8yJUnLYz3fnPdub/B+JhcTAF/Xl5ZdQVkvdh/K7pVp6HdL2G0qkJWu2YNRbkVVVtdWNmsENavNzITwcQYcspw6VKwtXJ/AT8WAJAjYmEgwIOLnAtIjLxvZrjODk5kOvoKEOb2lK3aGJQjlBi3wtj/XR/rIvr6mfPx9p36Fz3/mT2fTw0YVy6Q9PzfsJdwDJuBhm7beg/4EoRpGyV0EHmoJHgEEwQI/ZEEqcgB1lIUEfWIVHf8AR9C2OqyPUgNpyZRhhelefo5PAENcODY6YgoAEpfppvlCYxF66h/JJ/DHDudF0okPSdoFtE2bh/DJ8CnwpPiiJeSjXmtNrbqrlGDd66iXZJsPTT+VT+fIXY4ftiuAf+pHVCXmdDxNIiNiT8Ad8bSdFZ0P+wU/+Jr/2Q==");
    background-repeat: repeat;
    background-size: 160px 160px;
    background-attachment: fixed;
    opacity: 0.045;
    pointer-events: none;
    z-index: 0;
    mix-blend-mode: luminosity;
  }

  *,
  *::before,
  *::after {
    max-width: 100%;
  }

  ::-webkit-scrollbar {
    width: 2px
  }

  ::-webkit-scrollbar-track {
    background: var(--ink)
  }

  ::-webkit-scrollbar-thumb {
    background: var(--s3)
  }

  /*  NOISE GRAIN OVERLAY  */
  body::after {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 9000;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
    opacity: .5;
    mix-blend-mode: overlay;
  }

  /*  AMBIENT PARTICLES  */
  #ambient {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden
  }

  .amb {
    position: absolute;
    border-radius: 50%;
    animation: ambF linear infinite
  }

  @keyframes ambF {
    0% {
      transform: translateY(0) translateX(0) scale(1);
      opacity: 0
    }

    10% {
      opacity: 1
    }

    90% {
      opacity: .5
    }

    100% {
      transform: translateY(-100vh) translateX(var(--dx)) scale(.15);
      opacity: 0
    }
  }

  /*  SCROLL PROGRESS BAR  */
  #spbar {
    position: fixed;
    top: 0;
    left: 0;
    height: 2px;
    background: linear-gradient(to right, var(--g3), var(--g), var(--g2));
    z-index: 999;
    width: 0%;
    transition: width .1s linear
  }

  /*  NAV  */
  nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 500;
    padding: 16px 52px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all .5s
  }

  nav.scrolled {
    background: rgba(9, 9, 11, .96);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border);
    padding: 12px 52px
  }

  .nav-logo img {
    height: 60px;
    width: auto;
    filter: brightness(1.05);
    transition: transform .3s
  }

  .nav-logo:hover img {
    transform: scale(1.04)
  }

  .nav-links {
    display: flex;
    gap: 38px;
    list-style: none
  }

  .nav-links a {
    font-size: 9px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: rgba(245, 242, 236, .45);
    text-decoration: none;
    position: relative;
    transition: color .3s
  }

  .nav-links a::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--s);
    transition: width .35s
  }

  .nav-links a:hover {
    color: var(--s)
  }

  .nav-links a:hover::after {
    width: 100%
  }

  .nav-right {
    display: flex;
    align-items: center;
    gap: 16px
  }

  .cart-btn {
    position: relative;
    background: transparent;
    border: 1px solid rgba(200, 200, 200, .22);
    padding: 10px 22px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 9px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: rgba(200, 200, 200, .75);
    cursor: pointer;
    transition: all .35s
  }

  .cart-btn:hover {
    background: var(--g);
    color: var(--ink);
    border-color: var(--g)
  }

  .cart-count {
    position: absolute;
    top: -7px;
    right: -7px;
    background: var(--g);
    color: var(--ink);
    width: 17px;
    height: 17px;
    border-radius: 50%;
    font-size: 8px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0);
    transition: all .3s
  }

  .cart-count.show {
    opacity: 1;
    transform: scale(1)
  }

  /*  CART DRAWER  */
  .cart-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .75);
    z-index: 600;
    opacity: 0;
    pointer-events: none;
    transition: opacity .4s;
    backdrop-filter: blur(6px)
  }

  .cart-overlay.open {
    opacity: 1;
    pointer-events: all
  }

  .cart-drawer {
    position: fixed;
    right: 0;
    top: 0;
    bottom: 0;
    width: min(420px, 100vw);
    background: var(--panel);
    z-index: 601;
    transform: translateX(100%);
    transition: transform .48s cubic-bezier(.4, 0, .2, 1);
    display: flex;
    flex-direction: column;
    border-left: 1px solid var(--border)
  }

  .cart-drawer.open {
    transform: translateX(0)
  }

  .cart-header {
    padding: 26px 30px;
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center
  }

  .cart-header h3 {
    font-family: 'Cinzel', serif;
    font-size: 13px;
    letter-spacing: 5px;
    color: rgba(200, 200, 200, .9)
  }

  .cart-close {
    background: transparent;
    border: none;
    color: var(--muted);
    font-size: 20px;
    cursor: pointer;
    transition: color .3s;
    line-height: 1
  }

  .cart-close:hover {
    color: var(--s)
  }

  .cart-items {
    flex: 1;
    overflow-y: auto;
    padding: 22px 30px
  }

  .cart-empty {
    text-align: center;
    padding: 80px 0;
    color: var(--muted);
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase
  }

  .cart-item {
    display: flex;
    gap: 14px;
    padding: 18px 0;
    border-bottom: 1px solid var(--border);
    animation: sIn .3s ease
  }

  @keyframes sIn {
    from {
      opacity: 0;
      transform: translateX(16px)
    }

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

  .cart-item-img {
    width: 68px;
    height: 76px;
    background: var(--card);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border: 1px solid var(--border)
  }

  .cart-item-info {
    flex: 1
  }

  .cart-item-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 15px;
    color: var(--cream);
    margin-bottom: 3px
  }

  .cart-item-variant {
    font-size: 8px;
    letter-spacing: 3px;
    color: rgba(200, 200, 200, .5);
    text-transform: uppercase;
    margin-bottom: 8px
  }

  .cart-item-price {
    font-family: 'Cinzel', serif;
    font-size: 13px;
    color: var(--g)
  }

  .cart-item-controls {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 9px
  }

  .qty-btn {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--cream);
    width: 22px;
    height: 22px;
    cursor: pointer;
    font-size: 13px;
    transition: all .2s;
    display: flex;
    align-items: center;
    justify-content: center
  }

  .qty-btn:hover {
    border-color: var(--s);
    color: var(--s)
  }

  .qty-num {
    font-size: 11px;
    min-width: 18px;
    text-align: center
  }

  .remove-btn {
    margin-left: auto;
    background: transparent;
    border: none;
    color: rgba(245, 242, 236, .25);
    cursor: pointer;
    font-size: 10px;
    letter-spacing: 2px;
    text-transform: uppercase;
    transition: color .2s
  }

  .remove-btn:hover {
    color: #e06
  }

  .cart-footer {
    padding: 22px 30px;
    border-top: 1px solid var(--border)
  }

  .cart-total-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 7px;
    font-size: 10px;
    letter-spacing: 2px;
    color: var(--muted)
  }

  .cart-total-row.main {
    font-family: 'Cinzel', serif;
    font-size: 15px;
    color: var(--cream);
    letter-spacing: 3px;
    margin-bottom: 20px;
    margin-top: 7px
  }

  .checkout-btn {
    width: 100%;
    padding: 17px;
    background: linear-gradient(135deg, var(--g3), var(--g));
    color: var(--ink);
    border: none;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 10px;
    letter-spacing: 5px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all .35s;
    position: relative;
    overflow: hidden
  }

  .checkout-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--g), var(--g2));
    opacity: 0;
    transition: opacity .35s
  }

  .checkout-btn:hover::before {
    opacity: 1
  }

  .checkout-btn span {
    position: relative;
    z-index: 1
  }

  .checkout-btn:disabled {
    opacity: .4;
    cursor: not-allowed
  }

  /*  PAYMENT MODAL  */
  .modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .85);
    z-index: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .35s;
    backdrop-filter: blur(8px)
  }

  .modal-overlay.open {
    opacity: 1;
    pointer-events: all
  }

  .modal-box {
    background: var(--panel);
    border: 1px solid var(--border);
    width: min(500px, 94vw);
    padding: 44px;
    position: relative;
    max-height: 90vh;
    overflow-y: auto;
    animation: mUp .35s ease
  }

  @keyframes mUp {
    from {
      opacity: 0;
      transform: translateY(28px)
    }

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

  .modal-close {
    position: absolute;
    top: 18px;
    right: 22px;
    background: transparent;
    border: none;
    color: var(--muted);
    font-size: 20px;
    cursor: pointer;
    transition: color .3s
  }

  .modal-close:hover {
    color: var(--g)
  }

  .modal-title {
    font-family: 'Cinzel', serif;
    font-size: 15px;
    letter-spacing: 5px;
    color: var(--g);
    margin-bottom: 6px
  }

  .modal-sub {
    font-size: 9px;
    letter-spacing: 3px;
    color: var(--muted);
    margin-bottom: 28px;
    text-transform: uppercase
  }

  .order-summary {
    background: var(--card);
    padding: 18px;
    margin-bottom: 24px;
    border: 1px solid var(--border)
  }

  .order-row {
    display: flex;
    justify-content: space-between;
    font-size: 10px;
    color: var(--muted);
    margin-bottom: 7px;
    letter-spacing: 1px
  }

  .order-row.total {
    font-family: 'Cinzel', serif;
    font-size: 13px;
    color: var(--cream);
    border-top: 1px solid var(--border);
    padding-top: 10px;
    margin-top: 3px
  }

  .form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 18px
  }

  .form-full {
    grid-column: 1/-1
  }

  .form-group {
    display: flex;
    flex-direction: column;
    gap: 5px
  }

  .form-label {
    font-size: 8px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--muted)
  }

  .form-input {
    background: var(--card);
    border: 1px solid var(--border);
    padding: 11px 14px;
    color: var(--cream);
    font-family: 'Josefin Sans', sans-serif;
    font-size: 11px;
    outline: none;
    transition: border-color .3s
  }

  .form-input:focus {
    border-color: rgba(200, 200, 200, .45)
  }

  .rzp-btn {
    width: 100%;
    padding: 17px;
    background: linear-gradient(135deg, var(--g3), var(--g));
    color: var(--ink);
    border: none;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 10px;
    letter-spacing: 5px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all .35s;
    margin-top: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px
  }

  .rzp-btn:hover {
    background: linear-gradient(135deg, var(--g), var(--g2))
  }

  .payment-note {
    font-size: 8px;
    letter-spacing: 2px;
    color: rgba(245, 242, 236, .22);
    text-align: center;
    margin-top: 14px;
    text-transform: uppercase
  }

  /*  TOAST  */
  .toast {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 800;
    background: var(--panel);
    border-left: 3px solid var(--g);
    padding: 14px 22px;
    font-size: 10px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--g);
    transform: translateX(130%);
    transition: transform .4s cubic-bezier(.4, 0, .2, 1);
    max-width: 280px
  }

  .toast.show {
    transform: translateX(0)
  }


  /* ===== ENTRY PAGE ANIMATION OVERLAY ===== */
  #entryOverlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: var(--ink);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 32px;
    transition: opacity 1.2s ease, visibility 1.2s ease;
  }

  #entryOverlay.hide {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  .entry-logo-wrap {
    animation: entryLogoIn 1.4s cubic-bezier(.16, 1, .3, 1) both;
  }

  @keyframes entryLogoIn {
    from {
      opacity: 0;
      transform: translateY(40px) scale(0.92);
    }

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

  .entry-logo-wrap img {
    height: 80px;
    width: auto;
    filter: brightness(1.1);
  }

  .entry-tagline {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(16px, 2.5vw, 26px);
    font-style: italic;
    color: rgba(200, 200, 200, .55);
    letter-spacing: 4px;
    animation: entryLogoIn 1.4s .3s cubic-bezier(.16, 1, .3, 1) both;
  }

  .entry-line {
    width: 60px;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--s), transparent);
    animation: entryLineIn 1.8s .6s ease both;
  }

  @keyframes entryLineIn {
    from {
      transform: scaleX(0);
      opacity: 0;
    }

    to {
      transform: scaleX(1);
      opacity: 1;
    }
  }

  .entry-enter-btn {
    margin-top: 12px;
    background: transparent;
    border: 1px solid rgba(200, 200, 200, .35);
    color: rgba(200, 200, 200, .8);
    font-family: 'Josefin Sans', sans-serif;
    font-size: 9px;
    letter-spacing: 6px;
    text-transform: uppercase;
    padding: 14px 42px;
    cursor: pointer;
    transition: all .4s;
    animation: entryLogoIn 1.4s .9s cubic-bezier(.16, 1, .3, 1) both;
  }

  .entry-enter-btn:hover {
    background: var(--s);
    color: var(--ink);
    border-color: var(--s);
  }

  /* Progress bar animation on entry */
  .entry-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 2px;
    background: linear-gradient(to right, var(--g3), var(--g), var(--g2));
    animation: entryProgress 2.5s .3s ease forwards;
    width: 0%;
  }

  @keyframes entryProgress {
    to {
      width: 100%;
    }
  }

  /* ===== REVOLVING HERO IMAGE ===== */
  .hero-revolve-wrap {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .hero-revolve-wrap::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom,
        rgba(9, 9, 11, 0.60) 0%,
        rgba(9, 9, 11, 0.30) 40%,
        rgba(9, 9, 11, 0.55) 75%,
        rgba(9, 9, 11, 0.90) 100%);
    z-index: 2;
  }

  .hero-revolve-img {
    width: min(520px, 80vw);
    height: min(520px, 80vw);
    object-fit: cover;
    border-radius: 50%;
    opacity: .18;
    filter: grayscale(30%) brightness(.9);
    animation: revolveImg 18s linear infinite;
    transform-origin: center center;
    position: relative;
    z-index: 1;
    transition: opacity .9s ease;
  }

  .hero-revolve-img.fading {
    opacity: 0 !important;
  }

  @keyframes revolveImg {
    0% {
      transform: rotate(0deg) scale(1);
    }

    50% {
      transform: rotate(180deg) scale(1.04);
    }

    100% {
      transform: rotate(360deg) scale(1);
    }
  }

  /* Floating particles glow around image */
  .hero-revolve-glow {
    position: absolute;
    width: min(620px, 90vw);
    height: min(620px, 90vw);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(200, 200, 200, .06) 0%, transparent 70%);
    animation: revolveGlow 18s linear infinite;
    z-index: 1;
  }

  @keyframes revolveGlow {
    0% {
      transform: rotate(0deg);
    }

    100% {
      transform: rotate(-360deg);
    }
  }

  /* ===== HERO FLASHCARD BACKGROUND (kept for fallback) ===== */
  .hero-flashcards {
    display: none;
    /* replaced by revolve wrap */
  }

  .hfc-card {
    display: none;
  }

  /* ====================================== */

  /* 
   HERO
 */
  #hero {
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden
  }

  .hero-aura {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 60% at 50% 110%, rgba(200, 200, 200, .08) 0%, transparent 55%), radial-gradient(ellipse 35% 45% at 85% 5%, rgba(200, 200, 200, .07) 0%, transparent 50%)
  }

  /* Animated grid lines */
  .hero-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(200, 200, 200, .03) 1px, transparent 1px), linear-gradient(90deg, rgba(200, 200, 200, .03) 1px, transparent 1px);
    background-size: 60px 60px;
    animation: gridDrift 20s linear infinite
  }

  @keyframes gridDrift {
    0% {
      transform: translateY(0)
    }

    100% {
      transform: translateY(60px)
    }
  }

  .hero-inner {
    text-align: center;
    position: relative;
    z-index: 2
  }

  .hero-eyebrow {
    font-size: 9px;
    letter-spacing: 10px;
    color: rgba(200, 200, 200, .6);
    text-transform: uppercase;
    margin-bottom: 32px;
    animation: fu 1.2s .1s ease both;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px
  }

  .hero-eyebrow::before,
  .hero-eyebrow::after {
    content: '';
    width: 40px;
    height: 1px;
    background: linear-gradient(to right, transparent, rgba(200, 200, 200, .3))
  }

  .hero-eyebrow::after {
    background: linear-gradient(to left, transparent, rgba(200, 200, 200, .3))
  }

  .hero-h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(78px, 11.5vw, 155px);
    font-weight: 300;
    line-height: .82;
    letter-spacing: -2px;
    color: var(--cream);
    animation: fu 1.2s .25s ease both
  }

  .hero-h1 em {
    color: var(--g);
    font-style: italic;
    position: relative
  }

  .hero-h1 em::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(to right, var(--g3), var(--g), transparent);
    animation: lineGrow 1.5s 1.2s ease both
  }

  @keyframes lineGrow {
    from {
      transform: scaleX(0);
      transform-origin: left
    }

    to {
      transform: scaleX(1)
    }
  }

  .hero-tagline {
    font-family: 'Cormorant Garamond', serif;
    font-size: 20px;
    font-style: italic;
    color: rgba(200, 200, 200, .5);
    margin-top: 18px;
    animation: fu 1.2s .42s ease both
  }

  .hero-sub {
    font-size: 10px;
    letter-spacing: 6px;
    color: var(--muted);
    margin-top: 12px;
    text-transform: uppercase;
    animation: fu 1.2s .54s ease both
  }

  .hero-btns {
    margin-top: 52px;
    display: flex;
    gap: 16px;
    justify-content: center;
    animation: fu 1.2s .66s ease both
  }

  .btn-primary {
    display: inline-block;
    font-size: 9px;
    letter-spacing: 6px;
    text-transform: uppercase;
    color: var(--ink);
    background: linear-gradient(135deg, var(--g3), var(--g));
    padding: 17px 48px;
    text-decoration: none;
    transition: all .4s;
    position: relative;
    overflow: hidden
  }

  .btn-primary::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--g), var(--g2));
    opacity: 0;
    transition: opacity .4s
  }

  .btn-primary:hover::before {
    opacity: 1
  }

  .btn-primary span {
    position: relative;
    z-index: 1
  }

  .btn-outline {
    display: inline-block;
    font-size: 9px;
    letter-spacing: 6px;
    text-transform: uppercase;
    color: rgba(200, 200, 200, .8);
    border: 1px solid rgba(200, 200, 200, .28);
    padding: 17px 48px;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: color .4s
  }

  .btn-outline::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--g);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .4s
  }

  .btn-outline:hover::before {
    transform: scaleX(1)
  }

  .btn-outline:hover {
    color: var(--ink)
  }

  .btn-outline span {
    position: relative;
    z-index: 1
  }

  @keyframes fu {
    from {
      opacity: 0;
      transform: translateY(38px)
    }

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

  /* Floating bottle */
  /* hero bottle removed */

  .scroll-hint {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 9px;
    animation: fu 1.6s 1.3s ease both;
    opacity: 0
  }

  .scroll-hint span {
    font-size: 7px;
    letter-spacing: 5px;
    color: rgba(245, 242, 236, .2);
    text-transform: uppercase
  }

  .scroll-bar {
    width: 1px;
    height: 48px;
    background: linear-gradient(to bottom, var(--s), transparent);
    animation: sA 2s ease-in-out infinite
  }

  @keyframes sA {

    0%,
    100% {
      opacity: .25;
      transform: scaleY(1)
    }

    50% {
      opacity: .8;
      transform: scaleY(1.18)
    }
  }

  /*  STATS BAR  */
  .stats-bar {
    background: var(--panel);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 38px 60px;
    display: grid;
    grid-template-columns: repeat(4, 1fr)
  }

  .stat {
    text-align: center;
    border-right: 1px solid var(--border);
    padding: 0 20px;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .7s, transform .7s
  }

  .stat.vis {
    opacity: 1;
    transform: translateY(0)
  }

  .stat:last-child {
    border-right: none
  }

  .stat-num {
    font-family: 'Cinzel', serif;
    font-size: 36px;
    background: linear-gradient(135deg, var(--s), var(--g2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 8px;
    line-height: 1
  }

  .stat-label {
    font-size: 8px;
    letter-spacing: 4px;
    color: var(--muted);
    text-transform: uppercase
  }

  /*  MARQUEE BAND  */
  .marquee-band {
    background: var(--g);
    padding: 12px 0;
    overflow: hidden;
    position: relative
  }

  .marquee-track {
    display: flex;
    gap: 0;
    animation: marquee 18s linear infinite;
    white-space: nowrap
  }

  @keyframes marquee {
    0% {
      transform: translateX(0)
    }

    100% {
      transform: translateX(-50%)
    }
  }

  .marquee-item {
    font-family: 'Cinzel', serif;
    font-size: 10px;
    letter-spacing: 5px;
    color: var(--ink);
    padding: 0 32px;
    text-transform: uppercase;
    opacity: .85
  }

  /* ====================================================
     BRAND PILLARS — WILD CURVED EDITION
     ==================================================== */

  #brand-pillars {
    position: relative;
    z-index: 0;
    isolation: isolate;
    background: linear-gradient(175deg, #111114 0%, #0a0a0c 50%, #131317 100%);
    padding: 110px 0 130px;
    overflow: hidden;
  }

  /* Wave top/bottom */
  .pillars-wave {
    position: absolute;
    left: 0;
    width: 100%;
    height: 90px;
    pointer-events: none;
    z-index: 2;
  }
  .pillars-wave-top { top: 0; }
  .pillars-wave-bot { bottom: 0; }

  /* Floating ambient orbs */
  .p-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    pointer-events: none;
    animation: pOrbFloat ease-in-out infinite;
  }
  .p-orb1 {
    width: 380px; height: 380px;
    background: radial-gradient(circle, rgba(180,150,90,.12) 0%, transparent 70%);
    top: 10%; left: -8%;
    animation-duration: 14s;
  }
  .p-orb2 {
    width: 480px; height: 480px;
    background: radial-gradient(circle, rgba(130,110,70,.09) 0%, transparent 70%);
    top: 30%; right: -10%;
    animation-duration: 18s;
    animation-delay: -6s;
  }
  .p-orb3 {
    width: 320px; height: 320px;
    background: radial-gradient(circle, rgba(200,190,160,.07) 0%, transparent 70%);
    bottom: 15%; left: 40%;
    animation-duration: 11s;
    animation-delay: -3s;
  }
  @keyframes pOrbFloat {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-40px) scale(1.08); }
  }

  /* Decorative SVG curves */
  .p-diag-svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
  }

  /* Inner wrapper */
  .pillars-inner {
    position: relative;
    z-index: 3;
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 52px;
  }

  .pillars-hdr {
    text-align: center;
    margin-bottom: 90px;
  }

  /* ---- FLOW (staggered wave grid) ---- */
  .pillars-flow {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    align-items: start;
  }

  /* Stagger vertical offsets for wave effect */
  .pillar-card.pc-1 { margin-top: 0px;  }
  .pillar-card.pc-2 { margin-top: 60px; }
  .pillar-card.pc-3 { margin-top: 20px; }
  .pillar-card.pc-4 { margin-top: 80px; }

  /* Subtle individual rotations */
  .pillar-card.pc-1 { --r: -1.2deg; }
  .pillar-card.pc-2 { --r:  1.5deg; }
  .pillar-card.pc-3 { --r: -0.8deg; }
  .pillar-card.pc-4 { --r:  1.0deg; }

  .pillar-card {
    position: relative;
    background: rgba(22, 22, 28, 0.85);
    border: 1px solid rgba(200,200,200,.1);
    padding: 44px 32px 40px;
    overflow: hidden;
    cursor: default;
    border-radius: 2px;
    transform: rotate(var(--r, 0deg));
    transition:
      transform .55s cubic-bezier(.16,1,.3,1),
      border-color .4s,
      box-shadow .55s;
    /* Angled clip on top edge */
    clip-path: polygon(0 6%, 100% 0, 100% 100%, 0 100%);
  }

  /* Animated gradient border via pseudo-element */
  .pillar-card::after {
    content: '';
    position: absolute;
    inset: -1px;
    background: conic-gradient(
      from var(--a, 0deg),
      transparent 30%,
      rgba(200,180,120,.35) 50%,
      transparent 70%
    );
    border-radius: inherit;
    z-index: -1;
    opacity: 0;
    transition: opacity .5s;
    animation: pcRotate 6s linear infinite paused;
  }

  @keyframes pcRotate {
    to { --a: 360deg; }
  }

  @property --a {
    syntax: '<angle>';
    inherits: false;
    initial-value: 0deg;
  }

  .pillar-card:hover {
    transform: rotate(0deg) translateY(-12px) scale(1.02);
    border-color: rgba(200,180,120,.3);
    box-shadow:
      0 30px 80px rgba(0,0,0,.6),
      0 0 40px rgba(180,150,90,.08),
      inset 0 1px 0 rgba(200,200,200,.12);
  }

  .pillar-card:hover::after {
    opacity: 1;
    animation-play-state: running;
  }

  /* Glowing ring background element */
  .pc-ring {
    position: absolute;
    top: -60px;
    right: -60px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    border: 1px solid rgba(200,180,100,.06);
    box-shadow: 0 0 60px rgba(200,180,100,.04);
    transition: all .6s;
  }
  .pillar-card:hover .pc-ring {
    border-color: rgba(200,180,100,.18);
    box-shadow: 0 0 80px rgba(200,180,100,.12);
    transform: scale(1.2);
  }

  /* Ghost huge number behind content */
  .pc-ghost-num {
    position: absolute;
    bottom: -20px;
    right: -10px;
    font-family: 'Cinzel', serif;
    font-size: 120px;
    font-weight: 700;
    color: rgba(200,200,200,.025);
    line-height: 1;
    pointer-events: none;
    user-select: none;
    transition: color .5s, transform .5s;
  }
  .pillar-card:hover .pc-ghost-num {
    color: rgba(200,200,200,.055);
    transform: translateY(-8px) scale(1.04);
  }

  /* Small badge */
  .pc-badge {
    font-family: 'Cinzel', serif;
    font-size: 8px;
    letter-spacing: 5px;
    color: rgba(200,200,200,.25);
    margin-bottom: 26px;
    text-transform: uppercase;
    transition: color .3s;
  }
  .pillar-card:hover .pc-badge { color: rgba(200,180,100,.55); }

  /* Icon wrapper */
  .pc-icon-wrap {
    margin-bottom: 22px;
    width: 56px; height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(200,200,200,.04);
    border: 1px solid rgba(200,200,200,.08);
    border-radius: 50%;
    transition: background .4s, border-color .4s, transform .5s;
  }
  .pillar-card:hover .pc-icon-wrap {
    background: rgba(200,180,100,.07);
    border-color: rgba(200,180,100,.2);
    transform: rotate(-6deg) scale(1.08);
  }

  /* Title */
  .pc-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 30px;
    font-weight: 300;
    line-height: 1.1;
    color: var(--cream);
    margin-bottom: 14px;
  }
  .pc-title em {
    color: var(--g);
    font-style: italic;
  }

  /* Accent rule */
  .pc-rule {
    width: 0;
    height: 1px;
    background: linear-gradient(to right, rgba(200,180,100,.6), transparent);
    margin-bottom: 18px;
    transition: width .6s cubic-bezier(.16,1,.3,1);
  }
  .pillar-card:hover .pc-rule { width: 100%; }

  /* Body text */
  .pc-body {
    font-size: 11px;
    line-height: 2;
    color: var(--muted);
    letter-spacing: .3px;
    position: relative;
    z-index: 1;
  }

  /* Light-sweep shine on hover */
  .pc-shine {
    position: absolute;
    top: 0; left: -120%;
    width: 80%; height: 100%;
    background: linear-gradient(
      105deg,
      transparent 20%,
      rgba(255,255,255,.04) 50%,
      transparent 80%
    );
    pointer-events: none;
    transition: left .65s cubic-bezier(.16,1,.3,1);
  }
  .pillar-card:hover .pc-shine { left: 120%; }

  /*  SECTION HEADER  */
  .sec-hdr {
    text-align: center;
    margin-bottom: 88px
  }

  .sec-eye {
    font-size: 8px;
    letter-spacing: 8px;
    color: rgba(200, 200, 200, .5);
    text-transform: uppercase;
    margin-bottom: 18px
  }

  .sec-ttl {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(34px, 4.8vw, 66px);
    font-weight: 300;
    line-height: 1.05;
    color: var(--cream)
  }

  .sec-ttl em {
    color: var(--g);
    font-style: italic
  }

  .silver-line {
    width: 48px;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--s), transparent);
    margin: 28px auto
  }

  .silver-line.l {
    margin: 24px 0
  }

  /*  JOURNEY  */
  #journey {
    padding: 140px 0;
    position: relative;
    z-index: 1;
    overflow: hidden
  }

  .journey-spine {
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 1px;
    background: linear-gradient(to bottom, transparent, rgba(200, 200, 200, .18) 12%, rgba(200, 200, 200, .18) 88%, transparent)
  }

  .journey-wrap {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 60px
  }

  .j-item {
    display: grid;
    grid-template-columns: 1fr 88px 1fr;
    align-items: center;
    margin-bottom: 96px;
    opacity: 0;
    transform: translateY(44px);
    transition: opacity 1s, transform 1s
  }

  .j-item.vis {
    opacity: 1;
    transform: translateY(0)
  }

  .j-item:nth-child(odd) {
    transition-delay: .1s
  }

  .j-item:nth-child(even) {
    transition-delay: .2s
  }

  .j-text {
    padding: 0 44px
  }

  /* Desktop: even j-items have text on right side with left padding */
  .j-text.j-text-even {
    text-align: left;
    padding-left: 44px;
  }

  .j-text.r {
    text-align: right
  }

  .j-text h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 30px;
    font-weight: 400;
    color: var(--cream);
    margin-bottom: 10px
  }

  .j-text h3 span {
    color: var(--g)
  }

  .j-text p {
    font-size: 11px;
    line-height: 2;
    color: var(--muted)
  }

  .j-mid {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px
  }

  .j-yr {
    font-family: 'Cinzel', serif;
    font-size: 9px;
    letter-spacing: 3px;
    color: rgba(200, 200, 200, .55)
  }

  .j-dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--s);
    box-shadow: 0 0 14px rgba(200, 200, 200, .45), 0 0 28px rgba(200, 200, 200, .2);
    animation: dotPulse 2s ease-in-out infinite
  }

  @keyframes dotPulse {

    0%,
    100% {
      box-shadow: 0 0 14px rgba(200, 200, 200, .45), 0 0 28px rgba(200, 200, 200, .2)
    }

    50% {
      box-shadow: 0 0 22px rgba(200, 200, 200, .7), 0 0 44px rgba(200, 200, 200, .35)
    }
  }

  /* Journey icon wrapper */
  .j-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
  }

  /* Even items: icon sits on the left column (justify-self end on desktop) */
  .j-item:nth-child(even) .j-icon {
    justify-self: end;
  }

  /*  PRODUCTS  */
  #products {
    padding: 140px 60px;
    position: relative;
    z-index: 1;
    overflow: hidden
  }

  #products::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(to right, transparent 0%, rgba(200, 200, 200, .15) 30%, rgba(200, 200, 200, .15) 70%, transparent)
  }

  .prod-filters {
    display: flex;
    justify-content: center;
    gap: 3px;
    margin-bottom: 56px
  }

  .filter-btn {
    background: transparent;
    border: 1px solid rgba(200, 200, 200, .15);
    padding: 10px 26px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 8px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: var(--muted);
    cursor: pointer;
    transition: all .35s
  }

  .filter-btn.active,
  .filter-btn:hover {
    background: var(--g);
    color: var(--ink);
    border-color: var(--g)
  }

  .prod-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    max-width: 1220px;
    margin: 0 auto
  }

  .prod-card {
    opacity: 0;
    transform: translateY(40px) scale(.98);
    transition: opacity .8s, transform .8s;
    cursor: pointer
  }

  .prod-card.vis {
    opacity: 1;
    transform: translateY(0) scale(1)
  }

  .prod-visual {
    height: 400px;
    background: var(--card);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform .5s
  }

  .prod-card:hover .prod-visual {
    transform: scale(1.02)
  }

  .prod-visual::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 90%, rgba(200, 200, 200, .06) 0%, transparent 55%)
  }

  /* Animated shimmer */
  .prod-visual::after {
    content: '';
    position: absolute;
    top: -100%;
    left: -60%;
    width: 40%;
    height: 300%;
    background: linear-gradient(115deg, transparent 40%, rgba(200, 200, 200, .04) 50%, transparent 60%);
    transform: skewX(-12deg);
    transition: left .7s ease
  }

  .prod-card:hover .prod-visual::after {
    left: 160%
  }

  .prod-bg-ltr {
    position: absolute;
    font-family: 'Cinzel', serif;
    font-size: 120px;
    color: rgba(200, 200, 200, .025);
    font-weight: 700;
    user-select: none;
    transition: transform .5s, opacity .5s
  }

  .prod-card:hover .prod-bg-ltr {
    transform: scale(1.08);
    opacity: .06
  }

  .prod-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: linear-gradient(135deg, var(--g3), var(--g));
    color: var(--ink);
    font-size: 7px;
    letter-spacing: 3px;
    padding: 5px 11px;
    text-transform: uppercase
  }

  .prod-overlay {
    position: absolute;
    inset: 0;
    background: rgba(9, 9, 11, .88);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    opacity: 0;
    transition: opacity .4s
  }

  .prod-card:hover .prod-overlay {
    opacity: 1
  }

  /* Touch device support — show subtle overlay on tap/active */
  @media (pointer: coarse) {
    .prod-card:active .prod-overlay {
      opacity: 1;
    }
    /* Show a subtle tap indicator at bottom of card image */
    .prod-visual::before {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 36px;
      background: linear-gradient(to top, rgba(9,9,11,.55), transparent);
      z-index: 1;
    }
  }

  .prod-add-btn {
    font-size: 8px;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--s);
    border: 1px solid rgba(200, 200, 200, .4);
    padding: 12px 32px;
    cursor: pointer;
    background: transparent;
    font-family: 'Josefin Sans', sans-serif;
    transition: all .35s
  }

  .prod-add-btn:hover {
    background: var(--g);
    color: var(--ink)
  }

  .prod-info {
    padding: 20px 0
  }

  .prod-cat {
    font-size: 7px;
    letter-spacing: 4px;
    color: rgba(200, 200, 200, .4);
    text-transform: uppercase;
    margin-bottom: 5px
  }

  .prod-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 22px;
    font-weight: 400;
    color: var(--cream);
    margin-bottom: 5px
  }

  .prod-notes {
    font-size: 8px;
    letter-spacing: 2px;
    color: rgba(200, 200, 200, .4);
    text-transform: uppercase;
    margin-bottom: 10px
  }

  .prod-price {
    font-family: 'Cinzel', serif;
    font-size: 15px;
  }

  /*  WHY SECTION  */
  #why {
    padding: 120px 60px;
    background: var(--panel);
    position: relative;
    z-index: 1;
    overflow: hidden
  }

  #why::before {
    content: 'CRRISSEN';
    position: absolute;
    font-family: 'Cinzel', serif;
    font-size: 200px;
    font-weight: 700;
    color: rgba(200, 200, 200, .025);
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    white-space: nowrap
  }

  .why-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
    max-width: 1080px;
    margin: 0 auto
  }

  .why-card {
    background: var(--card);
    padding: 44px 30px;
    position: relative;
    overflow: hidden;
    cursor: default;
    opacity: 0;
    transform: translateY(32px) scale(.97);
    transition: opacity .8s, transform .8s
  }

  .why-card.vis {
    opacity: 1;
    transform: translateY(0) scale(1)
  }

  .why-card:hover {
    transform: translateY(-6px) scale(1) !important
  }

  .why-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(200, 200, 200, .04) 0%, transparent 60%);
    opacity: 0;
    transition: opacity .5s
  }

  .why-card:hover::before {
    opacity: 1
  }

  .why-card::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0%;
    height: 2px;
    background: linear-gradient(to right, var(--s3), var(--s));
    transition: width .5s ease
  }

  .why-card:hover::after {
    width: 100%
  }

  .why-icon {
    margin-bottom: 26px;
    transition: transform .4s
  }

  .why-card:hover .why-icon {
    transform: scale(1.12) rotate(3deg)
  }

  .why-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 22px;
    color: var(--cream);
    margin-bottom: 9px
  }

  .why-desc {
    font-size: 10px;
    line-height: 1.95;
    color: var(--muted)
  }

  /*  REVIEWS  */
  #reviews {
    padding: 120px 0;
    overflow: hidden;
    position: relative;
    z-index: 1;
  }

  .reviews-inner {
    padding: 0 60px
  }

  .reviews-track {
    display: flex;
    gap: 20px;
    overflow-x: auto;
    padding-bottom: 20px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    cursor: grab
  }

  .reviews-track::-webkit-scrollbar {
    height: 2px
  }

  .reviews-track::-webkit-scrollbar-thumb {
    background: var(--g3);
    border-radius: 1px
  }

  .reviews-track.grabbing {
    cursor: grabbing
  }

  .review-card {
    flex: 0 0 280px;
    background: var(--card);
    padding: 28px 24px;
    border: 1px solid var(--border);
    scroll-snap-align: start;
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .7s, transform .7s;
    position: relative;
    overflow: hidden
  }

  .review-card.vis {
    opacity: 1;
    transform: translateY(0)
  }

  .review-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(to right, transparent, var(--s), transparent);
    transform: scaleX(0);
    transition: transform .5s
  }

  .review-card:hover::before {
    transform: scaleX(1)
  }

  .stars {
    color: var(--g);
    font-size: 11px;
    letter-spacing: 3px;
    margin-bottom: 14px
  }

  .review-text {
    font-family: 'Cormorant Garamond', serif;
    font-size: 15px;
    font-style: italic;
    color: var(--cream);
    line-height: 1.6;
    margin-bottom: 14px
  }

  .review-author {
    font-size: 8px;
    letter-spacing: 3px;
    color: rgba(200, 200, 200, .38);
    text-transform: uppercase
  }

  .scroll-arrows {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 32px
  }

  .sarrow {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(200, 200, 200, .25);
    background: transparent;
    color: rgba(200, 200, 200, .6);
    cursor: pointer;
    font-size: 14px;
    transition: all .3s;
    display: flex;
    align-items: center;
    justify-content: center
  }

  .sarrow:hover {
    background: var(--g);
    color: var(--ink);
    border-color: var(--g)
  }

  /*  FAQ  */
  #faq {
    padding: 120px 60px;
    background: var(--panel);
    position: relative;
    z-index: 1;
  }

  .faq-wrap {
    max-width: 740px;
    margin: 0 auto
  }

  .faq-item {
    border-bottom: 1px solid var(--border);
    overflow: hidden
  }

  .faq-q {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 22px 0;
    cursor: pointer;
    font-size: 12px;
    letter-spacing: 2px;
    color: var(--cream);
    transition: color .3s
  }

  .faq-q:hover {
    color: var(--s)
  }

  .faq-icon {
    width: 22px;
    height: 22px;
    border: 1px solid rgba(200, 200, 200, .25);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    color: rgba(200, 200, 200, .6);
    transition: all .35s;
    flex-shrink: 0;
    margin-left: 18px
  }

  .faq-item.open .faq-icon {
    background: var(--g);
    color: var(--ink);
    border-color: var(--g);
    transform: rotate(45deg)
  }

  .faq-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease, padding .4s
  }

  .faq-a.open {
    max-height: 200px;
    padding-bottom: 18px
  }

  .faq-a p {
    font-size: 11px;
    line-height: 1.95;
    color: var(--muted);
    letter-spacing: .4px
  }

  /*  NEWSLETTER  */
  #newsletter {
    padding: 96px 60px;
    text-align: center;
    position: relative;
    z-index: 1;
    overflow: hidden
  }

  #newsletter::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(200, 200, 200, .03) 0%, transparent 65%)
  }

  .nl-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 46px;
    font-weight: 300;
    color: var(--cream);
    margin-bottom: 12px
  }

  .nl-title em {
    color: var(--g);
    font-style: italic
  }

  .nl-sub {
    font-size: 9px;
    letter-spacing: 4px;
    color: var(--muted);
    margin-bottom: 40px;
    text-transform: uppercase
  }

  .nl-form {
    display: flex;
    align-items: center;
    max-width: 420px;
    margin: 0 auto;
    border: 1px solid rgba(200, 200, 200, .2)
  }

  .nl-form input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    padding: 15px 18px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 10px;
    letter-spacing: 3px;
    color: var(--cream)
  }

  .nl-form input::placeholder {
    color: rgba(245, 242, 236, .2)
  }

  .nl-form button {
    background: linear-gradient(135deg, var(--g3), var(--g));
    border: none;
    padding: 15px 26px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 8px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: var(--ink);
    cursor: pointer;
    transition: all .35s
  }

  .nl-form button:hover {
    background: linear-gradient(135deg, var(--g), var(--g2))
  }

  /*  ORDER TRACKING MODAL  */
  .track-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 600;
    background: rgba(0, 0, 0, .82);
    backdrop-filter: blur(4px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 16px;
  }

  .track-modal-overlay.open {
    display: flex;
  }

  .track-modal {
    background: var(--panel);
    border: 1px solid var(--border);
    width: min(540px, 100%);
    max-height: 90vh;
    overflow-y: auto;
    padding: 36px 32px 32px;
    position: relative;
    scrollbar-width: thin;
  }

  .track-modal-close {
    position: absolute;
    top: 18px;
    right: 20px;
    background: none;
    border: none;
    color: var(--muted);
    font-size: 22px;
    cursor: pointer;
    line-height: 1;
    transition: color .2s;
  }

  .track-modal-close:hover {
    color: var(--cream);
  }

  .track-modal-title {
    font-family: 'Cinzel', serif;
    font-size: 14px;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--s);
    margin-bottom: 6px;
  }

  .track-modal-sub {
    font-size: 9px;
    letter-spacing: 2px;
    color: var(--muted);
    text-transform: uppercase;
    margin-bottom: 28px;
  }

  .track-input-row {
    display: flex;
    gap: 10px;
    margin-bottom: 8px;
  }

  .track-input {
    flex: 1;
    background: rgba(0, 0, 0, .5);
    border: 1px solid rgba(200, 200, 200, .16);
    color: var(--cream);
    padding: 13px 16px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 2px;
    outline: none;
    transition: border-color .3s;
  }

  .track-input:focus {
    border-color: rgba(200, 200, 200, .4);
  }

  .track-input::placeholder {
    color: rgba(245, 242, 236, .3);
  }

  .track-submit-btn {
    background: linear-gradient(135deg, var(--g3), var(--g));
    border: none;
    color: var(--ink);
    padding: 13px 28px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 9px;
    letter-spacing: 3px;
    text-transform: uppercase;
    cursor: pointer;
    transition: opacity .3s;
    white-space: nowrap;
  }

  .track-submit-btn:hover {
    opacity: .85;
  }

  .track-submit-btn:disabled {
    opacity: .4;
    cursor: default;
  }

  /* ── Result card ── */
  .track-result {
    margin-top: 24px;
    display: none;
  }

  .track-result.show {
    display: block;
  }

  .track-order-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 18px 20px;
    background: rgba(0, 0, 0, .3);
    border: 1px solid var(--border);
    margin-bottom: 24px;
  }

  .track-order-meta {
    display: flex;
    flex-direction: column;
    gap: 5px;
  }

  .track-order-id {
    font-family: 'Cinzel', serif;
    font-size: 12px;
    letter-spacing: 3px;
    color: var(--s);
  }

  .track-order-customer {
    font-size: 10px;
    letter-spacing: 1px;
    color: var(--cream);
  }

  .track-order-date {
    font-size: 8px;
    letter-spacing: 1px;
    color: var(--muted);
  }

  .track-order-total {
    font-family: 'Cinzel', serif;
    font-size: 16px;
    color: var(--cream);
    text-align: right;
  }

  .track-order-total-label {
    font-size: 7px;
    letter-spacing: 2px;
    color: var(--muted);
    text-align: right;
    margin-top: 3px;
  }

  .track-order-status {
    font-size: 7px;
    letter-spacing: 3px;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 1px;
    display: inline-block;
    margin-top: 6px;
  }

  /* ── Progress stepper ── */
  .track-progress {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    position: relative;
    margin-bottom: 28px;
    padding: 0 4px;
  }

  .track-progress::before {
    content: '';
    position: absolute;
    top: 13px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--border);
    z-index: 0;
  }

  .track-progress-fill {
    position: absolute;
    top: 13px;
    left: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--g3), var(--g));
    z-index: 1;
    transition: width .6s ease;
  }

  .track-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    font-size: 7px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--muted);
    position: relative;
    z-index: 2;
    flex: 1;
  }

  .track-step-dot {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--panel);
    border: 2px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 9px;
    color: var(--muted);
    transition: all .3s;
  }

  .track-step.done .track-step-dot {
    background: rgba(192, 192, 192, .15);
    border-color: var(--s);
    color: var(--s);
  }

  .track-step.done {
    color: var(--s);
  }

  .track-step.active .track-step-dot {
    background: var(--g);
    border-color: var(--g2);
    color: var(--ink);
    box-shadow: 0 0 12px rgba(200, 200, 200, .35);
  }

  .track-step.active {
    color: var(--g);
  }

  .track-step-dot svg {
    width: 11px;
    height: 11px;
  }

  .track-step-label {
    text-align: center;
    max-width: 56px;
    line-height: 1.4;
  }

  /* ── Items & Info ── */
  .tst-pending {
    background: rgba(255, 180, 0, .12);
    color: #f0a830;
  }

  .tst-confirmed {
    background: rgba(80, 160, 220, .12);
    color: rgba(80, 160, 220, .9);
  }

  .tst-shipped {
    background: rgba(140, 90, 220, .12);
    color: rgba(170, 130, 240, .9);
  }

  .tst-delivered {
    background: rgba(0, 200, 100, .2);
    color: rgba(80, 220, 130, .9);
  }

  .tst-cancelled {
    background: rgba(220, 60, 60, .12);
    color: rgba(220, 80, 80, .9);
  }

  .track-section-title {
    font-size: 7px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: var(--muted);
    margin: 20px 0 10px;
    border-top: 1px solid var(--border);
    padding-top: 16px;
  }

  .track-info-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
    font-size: 9px;
  }

  .track-info-key {
    color: rgba(192, 192, 192, .45);
    letter-spacing: 1px;
  }

  .track-info-val {
    color: var(--cream);
  }

  .track-item-row {
    display: flex;
    justify-content: space-between;
    padding: 9px 12px;
    background: rgba(0, 0, 0, .25);
    border: 1px solid rgba(255, 255, 255, .04);
    margin-bottom: 6px;
    font-size: 9px;
    color: var(--muted);
  }

  .track-item-name {
    color: var(--cream);
    letter-spacing: 1px;
  }

  .track-awb-block {
    margin-top: 16px;
    background: rgba(200, 200, 200, .06);
    border: 1px solid rgba(200, 200, 200, .2);
    padding: 16px 18px;
  }

  .track-awb-label {
    font-size: 7px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 6px;
  }

  .track-awb-num {
    font-family: 'Cinzel', serif;
    font-size: 13px;
    letter-spacing: 3px;
    color: var(--s);
  }

  .track-awb-courier {
    font-size: 8px;
    letter-spacing: 2px;
    color: var(--muted);
    margin-top: 4px;
  }

  .track-links-row {
    display: flex;
    gap: 12px;
    margin-top: 14px;
  }

  .track-ext-link {
    font-size: 8px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--s);
    text-decoration: none;
    border-bottom: 1px solid rgba(200, 200, 200, .3);
    padding-bottom: 1px;
    transition: border-color .2s;
  }

  .track-ext-link:hover {
    border-color: var(--s);
  }

  .track-steps {
    display: flex;
    justify-content: space-between;
    margin: 22px 0 0;
    position: relative;
  }

  .track-steps::before {
    content: '';
    position: absolute;
    top: 11px;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--border);
    z-index: 0;
  }

  .track-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    font-size: 7px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--muted);
    position: relative;
    z-index: 1;
  }

  .track-step-dot {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--panel);
    border: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .track-step.done .track-step-dot {
    background: rgba(192, 192, 192, .2);
    border-color: var(--s);
  }

  .track-step.done {
    color: var(--s);
  }

  .track-step.active .track-step-dot {
    background: var(--g);
    border-color: var(--g2);
  }

  .track-step.active {
    color: var(--g);
  }

  .track-step-dot svg {
    width: 10px;
    height: 10px;
  }

  .track-error {
    padding: 14px 16px;
    background: rgba(220, 60, 60, .08);
    border: 1px solid rgba(220, 60, 60, .2);
    font-size: 9px;
    letter-spacing: 2px;
    color: rgba(220, 80, 80, .9);
    margin-top: 16px;
    display: none;
  }

  .track-error.show {
    display: block;
  }

  /*  FOOTER  */
  footer {
    padding: 68px 60px 34px;
    border-top: 1px solid var(--border);
    position: relative;
    z-index: 1;
  }

  .foot-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 44px;
    margin-bottom: 60px
  }

  .foot-logo img {
    height: 56px;
    margin-bottom: 18px;
    filter: brightness(1.05)
  }

  .foot-tag {
    font-size: 10px;
    line-height: 1.95;
    color: rgba(245, 242, 236, .25);
    max-width: 230px
  }

  .foot-col h4 {
    font-size: 7px;
    letter-spacing: 5px;
    color: rgba(200, 200, 200, .4);
    text-transform: uppercase;
    margin-bottom: 20px
  }

  .foot-col a {
    display: block;
    font-size: 10px;
    color: rgba(245, 242, 236, .28);
    text-decoration: none;
    margin-bottom: 10px;
    letter-spacing: 1px;
    transition: all .3s;
    position: relative;
    padding-left: 0
  }

  .foot-col a::before {
    content: '';
    position: absolute;
    left: -12px;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 1px;
    background: var(--s);
    transition: width .3s
  }

  .foot-col a:hover {
    color: rgba(200, 200, 200, .85);
    padding-left: 14px
  }

  .foot-col a:hover::before {
    width: 8px
  }

  .foot-bottom {
    border-top: 1px solid rgba(200, 200, 200, .06);
    padding-top: 30px;
    display: flex;
    justify-content: space-between;
    font-size: 8px;
    letter-spacing: 3px;
    color: rgba(245, 242, 236, .14)
  }

  /*  REVEAL BASE  */
  .reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 1s, transform 1s
  }

  .reveal.vis {
    opacity: 1;
    transform: translateY(0)
  }

  /* 
     MOBILE & TABLET RESPONSIVE  — CRRISSEN
     Breakpoints: 768px (tablet), 480px (phone)
   */

  /*  HAMBURGER BUTTON  */
  .nav-hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 8px;
    background: transparent;
    border: none;
    z-index: 600;
  }

  .nav-hamburger span {
    display: block;
    width: 24px;
    height: 1.5px;
    background: var(--s);
    transition: all .35s ease;
    transform-origin: center;
  }

  .nav-hamburger.open span:nth-child(1) {
    transform: translateY(6.5px) rotate(45deg);
  }

  .nav-hamburger.open span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
  }

  .nav-hamburger.open span:nth-child(3) {
    transform: translateY(-6.5px) rotate(-45deg);
  }

  /*  MOBILE NAV DRAWER  */
  .nav-mobile-drawer {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(9, 9, 11, .98);
    z-index: 550;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 36px;
    backdrop-filter: blur(20px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .4s;
  }

  .nav-mobile-drawer.open {
    opacity: 1;
    pointer-events: all;
  }

  .nav-mobile-drawer a {
    font-size: 13px;
    letter-spacing: 6px;
    text-transform: uppercase;
    color: var(--muted);
    text-decoration: none;
    transition: color .3s;
  }

  .nav-mobile-drawer a:hover {
    color: var(--s);
  }

  .nav-mobile-drawer .mobile-cart-btn {
    margin-top: 12px;
    background: transparent;
    border: 1px solid rgba(200, 200, 200, .3);
    padding: 14px 40px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 10px;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--s);
    cursor: pointer;
    transition: all .3s;
    position: relative;
  }

  .nav-mobile-drawer .mobile-cart-btn:hover {
    background: var(--g);
    border-color: var(--g);
    color: var(--ink);
  }

  @media (max-width: 768px) {

    /* BRAND PILLARS RESPONSIVE */
    #brand-pillars {
      padding: 80px 0;
    }
    .pillars-inner {
      padding: 0 20px;
    }
    .pillars-flow {
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    /* Reset stagger & rotation on tablet */
    .pillar-card.pc-1,
    .pillar-card.pc-2,
    .pillar-card.pc-3,
    .pillar-card.pc-4 {
      margin-top: 0;
      transform: rotate(0deg);
      clip-path: none;
    }


    nav {
      padding: 14px 20px;
    }

    nav.scrolled {
      padding: 11px 20px;
    }

    .nav-links {
      display: none;
    }

    .nav-right .cart-btn {
      display: none;
    }

    .nav-hamburger {
      display: flex;
    }

    .nav-mobile-drawer {
      display: flex;
    }

    /*  HERO  */
    #hero {
      height: 100vh;
      height: 100svh;
      align-items: center;
      padding: 80px 0 60px;
    }

    .hero-inner {
      padding: 0 24px;
      text-align: center;
    }

    .hero-h1 {
      font-size: clamp(58px, 14vw, 96px);
      letter-spacing: -1px;
    }

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

    .hero-sub {
      font-size: 8px;
      letter-spacing: 4px;
    }

    .hero-btns {
      flex-direction: column;
      align-items: center;
      gap: 12px;
      margin-top: 36px;
    }

    .btn-primary,
    .btn-outline {
      padding: 15px 40px;
      font-size: 9px;
    }

    .scroll-hint {
      bottom: 20px;
    }

    /*  NAV  */
    .nav-logo img {
      height: 48px;
    }

    /*  STATS BAR  */
    .stats-bar {
      grid-template-columns: repeat(2, 1fr);
      padding: 28px 20px;
      gap: 0;
    }

    .stat {
      padding: 16px 10px;
      border-right: none;
      border-bottom: 1px solid var(--border);
    }

    .stat:nth-child(odd) {
      border-right: 1px solid var(--border);
    }

    .stat:nth-child(3),
    .stat:nth-child(4) {
      border-bottom: none;
    }

    .stat-num {
      font-size: 26px;
    }

    /*  BOTTLE CANVAS SECTION  */
    #bottle-canvas-section {
      height: 280vh;
    }

    .bcs-sticky {
      flex-direction: column;
      justify-content: center;
      gap: 0;
    }

    .bcs-text-left {
      position: relative;
      left: auto;
      top: auto;
      bottom: auto;
      transform: none;
      width: 90%;
      max-width: 340px;
      text-align: center;
      padding: 0 16px;
      margin-top: 16px;
    }

    .bc-panel {
      position: relative;
      top: auto;
      left: auto;
    }

    .bc-title {
      font-size: 26px;
    }

    .bc-num {
      font-size: 7px;
    }

    .bc-body {
      font-size: 10px;
      line-height: 1.75;
    }

    #bigBottle {
      width: 110px !important;
      margin-top: 20px;
    }

    #branchCanvas {
      opacity: .4;
    }

    .bc-progress {
      bottom: 16px;
    }

    /*  JOURNEY / OUR STORY  */
    #journey {
      padding: 80px 0;
    }

    .journey-wrap {
      padding: 0 16px;
    }

    .journey-spine {
      display: none;
    }

    .j-item {
      grid-template-columns: 1fr !important;
      grid-template-rows: auto;
      margin-bottom: 44px;
      text-align: left;
    }

    /* Hide the icon column on mobile */
    .j-icon {
      display: none !important;
    }

    .j-mid {
      order: 1;
      flex-direction: row;
      justify-content: flex-start;
      margin-bottom: 10px;
      gap: 10px;
    }

    .j-text {
      order: 2;
      padding: 0 !important;
      text-align: left !important;
    }

    .j-text.r {
      text-align: left !important;
    }

    /* Fix inline style padding-left on even items */
    .j-item > div[style*="padding-left"] {
      padding-left: 0 !important;
      text-align: left !important;
    }

    .j-text h3 {
      font-size: 22px;
    }

    .j-text p {
      font-size: 11px;
      line-height: 1.8;
    }

    .silver-line.l {
      margin: 8px 0 !important;
    }

    /*  PRODUCTS  */
    #products {
      padding: 80px 20px;
    }

    .prod-filters {
      flex-wrap: wrap;
      gap: 6px;
    }

    .filter-btn {
      padding: 9px 18px;
      font-size: 8px;
    }

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

    .prod-visual {
      height: 260px;
    }

    .prod-name {
      font-size: 17px;
    }

    .sec-hdr {
      margin-bottom: 44px;
    }

    /*  WHY  */
    #why {
      padding: 80px 20px;
    }

    .why-grid {
      grid-template-columns: 1fr;
      gap: 2px;
      max-width: 100%;
    }

    .why-card:hover {
      transform: none !important;
    }

    /*  REVIEWS  */
    #reviews {
      padding: 80px 0;
    }

    .reviews-inner {
      padding: 0 16px;
    }

    .reviews-track {
      gap: 14px;
      padding-bottom: 16px;
      /* enable smooth momentum scrolling on iOS */
      -webkit-overflow-scrolling: touch;
    }

    .review-card {
      flex: 0 0 min(260px, 78vw);
    }

    .review-text {
      font-size: 14px;
    }

    .scroll-arrows {
      margin-top: 20px;
    }

    /*  FAQ  */
    #faq {
      padding: 80px 20px;
    }

    .faq-q {
      font-size: 11px;
    }

    /*  NEWSLETTER  */
    #newsletter {
      padding: 64px 20px;
    }

    .nl-title {
      font-size: 32px;
    }

    .nl-form {
      flex-direction: column;
      border: none;
      gap: 0;
    }

    .nl-form input {
      border: 1px solid rgba(200, 200, 200, .2);
      padding: 14px 18px;
      text-align: center;
    }

    .nl-form button {
      padding: 14px;
      width: 100%;
      border: 1px solid rgba(200, 200, 200, .2);
      border-top: none;
    }

    /*  FOOTER  */
    footer {
      padding: 48px 20px 28px;
    }

    .foot-grid {
      grid-template-columns: 1fr 1fr;
      gap: 32px;
    }

    .foot-grid>div:first-child {
      grid-column: 1 / -1;
    }

    .foot-logo img {
      height: 44px;
    }

    .foot-bottom {
      flex-direction: column;
      gap: 8px;
      text-align: center;
    }

    /*  PAYMENT MODAL  */
    .modal-box {
      padding: 28px 20px;
    }

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

    /*  CART DRAWER  */
    .cart-drawer {
      width: 100vw;
    }

    .cart-header {
      padding: 18px 16px;
    }

    .cart-items {
      padding: 12px 16px;
    }

    .cart-footer {
      padding: 14px 16px;
    }

    .cart-item-name {
      font-size: 14px;
    }

    .cart-item-img {
      width: 56px;
      height: 64px;
    }

  }

  @media (max-width: 480px) {

    /* BRAND PILLARS SINGLE COLUMN */
    .pillars-flow {
      grid-template-columns: 1fr;
    }

    /*  HERO  */
    .hero-h1 {
      font-size: clamp(46px, 13vw, 72px);
    }

    .hero-eyebrow {
      font-size: 7px;
      letter-spacing: 6px;
    }

    .hero-btns {
      gap: 10px;
    }

    .btn-primary,
    .btn-outline {
      padding: 14px 32px;
      font-size: 8px;
      letter-spacing: 4px;
    }

    /*  PRODUCTS  */
    .prod-grid {
      grid-template-columns: 1fr;
      max-width: 360px;
      margin: 0 auto;
    }

    .prod-visual {
      height: 300px;
    }

    /*  STATS  */
    .stats-bar {
      grid-template-columns: 1fr 1fr;
      padding: 20px 14px;
    }

    .stat-num {
      font-size: 22px;
    }

    /*  WHY  */
    .why-card {
      padding: 32px 20px;
    }

    /*  FOOTER  */
    .foot-grid {
      grid-template-columns: 1fr;
    }

    /*  SECTION TITLE SIZES  */
    .sec-ttl {
      font-size: clamp(28px, 8vw, 48px);
    }

    .bc-title {
      font-size: 24px;
    }

    .nl-title {
      font-size: 26px;
    }

    /*  PROD OVERLAY on small phones: tap-friendly btn  */
    .prod-overlay {
      /* Always slightly visible on mobile so users know it's tappable */
      opacity: 0;
    }

    .prod-add-btn {
      padding: 12px 24px;
      font-size: 8px;
      letter-spacing: 3px;
    }

    /* REVIEWS on small phones */
    .review-card {
      flex: 0 0 min(240px, 82vw);
      padding: 22px 18px;
    }

    /* PRODUCT MODAL full screen on very small phones */
    .prod-modal-box {
      width: 100vw;
      max-height: 100svh;
      max-height: 100vh;
    }

    .prod-modal-img-wrap {
      min-height: 200px;
      padding: 20px 16px;
    }

    .prod-modal-img-wrap img {
      max-height: 170px;
    }

    .prod-modal-body {
      padding: 20px 16px 28px;
    }

    .prod-modal-name {
      font-size: clamp(16px, 5vw, 22px);
      letter-spacing: 1px;
    }

    .prod-modal-desc {
      font-size: 13px;
    }

    /* JOURNEY / OUR STORY on very small phones */
    .j-text h3 {
      font-size: 20px;
    }

    /* REVIEW FORM in orders modal */
    .review-form-wrap textarea {
      min-height: 70px;
      font-size: 12px;
    }

    /* ORDER MODAL better fit */
    #ordersScrollArea {
      max-height: 80vh;
    }

    /* CHECKOUT steps labels shorter */
    .chk-step-tab {
      font-size: 7px;
      letter-spacing: 2px;
      padding: 12px 4px;
    }

    /* OTP boxes fit better */
    .otp-box {
      width: 34px;
      height: 42px;
      font-size: 15px;
    }

    #otpBoxes {
      gap: 5px;
    }

  }

  /*  CHECKOUT STEPS  */
  .chk-step-tab {
    flex: 1;
    padding: 14px 8px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 8px;
    letter-spacing: 3px;
    text-transform: uppercase;
    text-align: center;
    color: var(--muted);
    cursor: default;
    border-right: 1px solid var(--border);
    transition: all .3s;
  }

  .chk-step-tab:last-child {
    border-right: none
  }

  .chk-step-tab.active {
    color: var(--s);
    background: rgba(200, 200, 200, .05)
  }

  .chk-step-tab.done {
    color: rgba(80, 200, 120, .8)
  }

  /* OTP boxes */
  .otp-box {
    width: 44px;
    height: 52px;
    text-align: center;
    background: var(--card);
    border: 1px solid var(--border);
    font-family: 'Cinzel', serif;
    font-size: 20px;
    color: var(--cream);
    outline: none;
    transition: border-color .3s;
    caret-color: var(--s);
  }

  .otp-box:focus {
    border-color: var(--s)
  }

  .otp-box.filled {
    border-color: rgba(80, 200, 120, .5);
    color: rgba(80, 200, 120, .9)
  }

  @media(max-width:480px) {
    .otp-box {
      width: 36px;
      height: 44px;
      font-size: 16px
    }
  }

  /*  LOGIN MODAL  */
  #loginModal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .9);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .4s ease;
    backdrop-filter: blur(12px);
  }

  #loginModal.open {
    opacity: 1;
    pointer-events: all
  }

  .login-modal-box {
    background: var(--panel);
    border: 1px solid var(--border);
    width: min(440px, 96vw);
    position: relative;
    animation: mUp .35s ease;
    max-height: 90vh;
    overflow-y: auto
  }

  .login-tabs {
    display: flex;
    border-bottom: 1px solid var(--border)
  }

  .login-tab {
    flex: 1;
    padding: 16px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 9px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: var(--muted);
    cursor: pointer;
    transition: all .3s;
    background: transparent;
    border: none;
    text-align: center
  }

  .login-tab.active {
    color: var(--s);
    border-bottom: 2px solid var(--s)
  }

  .login-body {
    padding: 32px
  }

  .login-form {
    display: none
  }

  .login-form.active {
    display: block
  }

  .login-field {
    margin-bottom: 16px
  }

  .login-field label {
    display: block;
    font-size: 8px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 6px
  }

  .login-field input {
    width: 100%;
    background: var(--card);
    border: 1px solid var(--border);
    padding: 12px 14px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 11px;
    color: var(--cream);
    outline: none;
    transition: border-color .3s
  }

  .login-field input:focus {
    border-color: var(--s)
  }

  .login-action-btn {
    width: 100%;
    padding: 15px;
    background: var(--s);
    color: var(--ink);
    border: none;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 10px;
    letter-spacing: 5px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .3s;
    margin-top: 8px
  }

  .login-action-btn:hover {
    background: var(--s2)
  }

  .login-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 20px 0
  }

  .login-divider span {
    font-size: 8px;
    letter-spacing: 3px;
    color: var(--muted);
    text-transform: uppercase;
    white-space: nowrap
  }

  .login-divider::before,
  .login-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border)
  }

  .login-skip {
    display: block;
    text-align: center;
    font-size: 9px;
    letter-spacing: 3px;
    color: var(--muted);
    text-transform: uppercase;
    margin-top: 16px;
    cursor: pointer;
    transition: color .3s;
    background: transparent;
    border: none;
    font-family: 'Josefin Sans', sans-serif;
    width: 100%;
    padding: 8px
  }

  .login-skip:hover {
    color: var(--s)
  }

  /*  USER PILL in nav  */
  .user-pill {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(200, 200, 200, .08);
    border: 1px solid var(--border);
    padding: 7px 14px;
    cursor: pointer;
    transition: all .3s;
    position: relative
  }

  .user-pill:hover {
    border-color: var(--s)
  }

  .user-pill img {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    object-fit: cover
  }

  .user-pill-name {
    font-size: 8px;
    letter-spacing: 2px;
    color: var(--s);
    text-transform: uppercase
  }

  .user-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: var(--panel);
    border: 1px solid var(--border);
    min-width: 180px;
    z-index: 200;
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s;
    transform: translateY(4px)
  }

  .user-pill.open .user-dropdown {
    opacity: 1;
    pointer-events: all;
    transform: translateY(0)
  }

  .user-dropdown a {
    display: block;
    padding: 12px 18px;
    font-size: 9px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--muted);
    text-decoration: none;
    transition: all .2s;
    cursor: pointer
  }

  .user-dropdown a:hover {
    color: var(--cream);
    background: rgba(200, 200, 200, .05)
  }

  .user-dropdown a.danger:hover {
    color: rgba(220, 80, 80, .85)
  }

  /*  ORDER TRACKING modal  */
  .track-timeline {
    margin-top: 20px
  }

  .track-step {
    display: flex;
    gap: 16px;
    margin-bottom: 0;
    position: relative
  }

  .track-step::before {
    content: '';
    position: absolute;
    left: 11px;
    top: 24px;
    bottom: -24px;
    width: 1px;
    background: var(--border)
  }

  .track-step:last-child::before {
    display: none
  }

  .track-dot {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 2px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 9px;
    margin-top: 2px;
    transition: all .4s
  }

  .track-dot.done {
    background: var(--s);
    border-color: var(--s);
    color: var(--ink)
  }

  .track-dot.current {
    background: rgba(200, 200, 200, .2);
    border-color: var(--g);
    color: var(--g)
  }

  .track-info {
    padding-bottom: 24px
  }

  .track-label {
    font-size: 11px;
    color: var(--cream);
    letter-spacing: 1px;
    margin-bottom: 3px
  }

  .track-sub {
    font-size: 9px;
    letter-spacing: 1px;
    color: var(--muted)
  }

  .use-location-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    border: 1px solid var(--border);
    padding: 10px 14px;
    font-family: 'Josefin Sans', sans-serif;
    font-size: 9px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--muted);
    cursor: pointer;
    transition: all .3s;
    margin-bottom: 10px
  }

  .use-location-btn:hover {
    border-color: var(--s);
    color: var(--s)
  }

  /* ── PRODUCT DETAIL MODAL ─────────────────────── */
  #prodModal {
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
  }

  #prodModal.open {
    opacity: 1;
    pointer-events: all;
  }

  .prod-modal-box {
    background: var(--panel);
    border: 1px solid var(--border);
    width: min(820px, 96vw);
    max-height: 90vh;
    overflow-y: auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    position: relative;
    animation: mUp .35s ease;
    scrollbar-width: none;
  }

  .prod-modal-box::-webkit-scrollbar {
    display: none;
  }

  @media (max-width: 620px) {
    .prod-modal-box {
      grid-template-columns: 1fr;
      width: min(820px, 100vw);
      max-height: 100svh;
      max-height: 100vh;
      border-radius: 0;
    }

    .prod-modal-img-wrap {
      min-height: 220px;
      max-height: 260px;
      border-right: none;
      border-bottom: 1px solid var(--border);
      padding: 24px 20px;
    }

    .prod-modal-img-wrap img {
      max-height: 200px;
      width: auto;
      max-width: 100%;
      object-fit: contain;
    }

    .prod-modal-body {
      padding: 24px 20px 32px;
    }

    .prod-modal-name {
      font-size: clamp(18px, 5vw, 26px);
    }

    .prod-modal-atc {
      padding: 18px;
      font-size: 10px;
    }
  }

  .prod-modal-img-wrap {
    background: var(--card);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 340px;
    padding: 40px 32px;
    border-right: 1px solid var(--border);
    position: relative;
    overflow: hidden;
  }

  .prod-modal-img-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 30%, rgba(201, 169, 110, .1) 0%, transparent 70%);
  }

  .prod-modal-img-wrap img {
    max-height: 280px;
    max-width: 100%;
    object-fit: contain;
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 8px 28px rgba(0, 0, 0, .7));
  }

  .prod-modal-img-wrap svg {
    position: relative;
    z-index: 1;
  }

  .prod-modal-body {
    padding: 44px 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .prod-modal-cat {
    font-size: 8px;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--g);
    margin-bottom: 10px;
  }

  .prod-modal-name {
    font-family: 'Cinzel', serif;
    font-size: clamp(22px, 3.5vw, 32px);
    color: var(--cream);
    letter-spacing: 2px;
    margin-bottom: 8px;
  }

  .prod-modal-notes {
    font-size: 9px;
    letter-spacing: 4px;
    color: rgba(200, 200, 200, .55);
    text-transform: uppercase;
    margin-bottom: 22px;
  }

  .prod-modal-divider {
    width: 36px;
    height: 1px;
    background: var(--g);
    margin-bottom: 20px;
    opacity: .6;
  }

  .prod-modal-desc {
    font-family: 'Cormorant Garamond', serif;
    font-size: 15px;
    line-height: 1.75;
    color: rgba(245, 242, 236, .72);
    margin-bottom: 20px;
  }

  .prod-modal-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 24px;
  }

  .prod-modal-tag {
    font-size: 7px;
    letter-spacing: 3px;
    text-transform: uppercase;
    border: 1px solid var(--border);
    color: var(--muted);
    padding: 5px 10px;
  }

  .prod-modal-price {
    font-family: 'Cinzel', serif;
    font-size: 22px;
    color: var(--g);
    letter-spacing: 2px;
    margin-bottom: 4px;
  }

  .prod-modal-vol {
    font-size: 8px;
    letter-spacing: 3px;
    color: var(--muted);
    text-transform: uppercase;
    margin-bottom: 24px;
  }

  .prod-modal-atc {
    width: 100%;
    padding: 16px;
    background: transparent;
    border: 1px solid var(--s);
    font-family: 'Josefin Sans', sans-serif;
    font-size: 9px;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--s);
    cursor: pointer;
    transition: all .35s;
  }

  .prod-modal-atc:hover {
    background: var(--s);
    color: var(--ink);
  }

  .prod-card {
    cursor: pointer;
  }

  /* Pricing MRP */
  .prod-mrp, .modal-mrp, .cart-item-mrp, .checkout-mrp {
    text-decoration: line-through;
    color: var(--s3);
    font-size: 0.85em;
    margin-right: 6px;
    opacity: 0.7;
  }
  .prod-price-current {
    font-weight: 600;
    background: linear-gradient(to right, var(--g), var(--g2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }
  .modal-price-current, .cart-item-price-current, .checkout-price-current {
    color: var(--g);
    font-weight: 600;
  }
  .prod-price {
    display: flex;
    align-items: center;
    gap: 4px;
  }