@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500&family=Playfair+Display:wght@500;600&display=swap');@import url('https://cdn.jsdelivr.net/npm/@tabler/icons-webfont@3.24.0/dist/tabler-icons.min.css');

/* required styles */
.leaflet-pane,
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-tile-container,
.leaflet-pane > svg,
.leaflet-pane > canvas,
.leaflet-zoom-box,
.leaflet-image-layer,
.leaflet-layer {
	position: absolute;
	left: 0;
	top: 0;
	}
.leaflet-container {
	overflow: hidden;
	}
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow {
	-webkit-user-select: none;
	   -moz-user-select: none;
	        user-select: none;
	  -webkit-user-drag: none;
	}
/* Prevents IE11 from highlighting tiles in blue */
.leaflet-tile::-moz-selection {
	background: transparent;
}
.leaflet-tile::selection {
	background: transparent;
}
/* Safari renders non-retina tile on retina better with this, but Chrome is worse */
.leaflet-safari .leaflet-tile {
	image-rendering: -webkit-optimize-contrast;
	}
/* hack that prevents hw layers "stretching" when loading new tiles */
.leaflet-safari .leaflet-tile-container {
	width: 1600px;
	height: 1600px;
	-webkit-transform-origin: 0 0;
	}
.leaflet-marker-icon,
.leaflet-marker-shadow {
	display: block;
	}
/* .leaflet-container svg: reset svg max-width decleration shipped in Joomla! (joomla.org) 3.x */
/* .leaflet-container img: map is broken in FF if you have max-width: 100% on tiles */
.leaflet-container .leaflet-overlay-pane svg {
	max-width: none !important;
	max-height: none !important;
	}
.leaflet-container .leaflet-marker-pane img,
.leaflet-container .leaflet-shadow-pane img,
.leaflet-container .leaflet-tile-pane img,
.leaflet-container img.leaflet-image-layer,
.leaflet-container .leaflet-tile {
	max-width: none !important;
	max-height: none !important;
	width: auto;
	padding: 0;
	}
.leaflet-container img.leaflet-tile {
	/* See: https://bugs.chromium.org/p/chromium/issues/detail?id=600120 */
	mix-blend-mode: plus-lighter;
}
.leaflet-container.leaflet-touch-zoom {
	touch-action: pan-x pan-y;
	}
.leaflet-container.leaflet-touch-drag {
	/* Fallback for FF which doesn't support pinch-zoom */
	touch-action: none;
	touch-action: pinch-zoom;
}
.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom {
	touch-action: none;
}
.leaflet-container {
	-webkit-tap-highlight-color: transparent;
}
.leaflet-container a {
	-webkit-tap-highlight-color: rgba(51, 181, 229, 0.4);
}
.leaflet-tile {
	filter: inherit;
	visibility: hidden;
	}
.leaflet-tile-loaded {
	visibility: inherit;
	}
.leaflet-zoom-box {
	width: 0;
	height: 0;
	box-sizing: border-box;
	z-index: 800;
	}
/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */
.leaflet-overlay-pane svg {
	-moz-user-select: none;
	}
.leaflet-pane         { z-index: 400; }
.leaflet-tile-pane    { z-index: 200; }
.leaflet-overlay-pane { z-index: 400; }
.leaflet-shadow-pane  { z-index: 500; }
.leaflet-marker-pane  { z-index: 600; }
.leaflet-tooltip-pane   { z-index: 650; }
.leaflet-popup-pane   { z-index: 700; }
.leaflet-map-pane canvas { z-index: 100; }
.leaflet-map-pane svg    { z-index: 200; }
.leaflet-vml-shape {
	width: 1px;
	height: 1px;
	}
.lvml {
	behavior: url(#default#VML);
	display: inline-block;
	position: absolute;
	}
/* control positioning */
.leaflet-control {
	position: relative;
	z-index: 800;
	pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
	pointer-events: auto;
	}
.leaflet-top,
.leaflet-bottom {
	position: absolute;
	z-index: 1000;
	pointer-events: none;
	}
.leaflet-top {
	top: 0;
	}
.leaflet-right {
	right: 0;
	}
.leaflet-bottom {
	bottom: 0;
	}
.leaflet-left {
	left: 0;
	}
.leaflet-control {
	float: left;
	clear: both;
	}
.leaflet-right .leaflet-control {
	float: right;
	}
.leaflet-top .leaflet-control {
	margin-top: 10px;
	}
.leaflet-bottom .leaflet-control {
	margin-bottom: 10px;
	}
.leaflet-left .leaflet-control {
	margin-left: 10px;
	}
.leaflet-right .leaflet-control {
	margin-right: 10px;
	}
/* zoom and fade animations */
.leaflet-fade-anim .leaflet-popup {
	opacity: 0;
	transition: opacity 0.2s linear;
	}
.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
	opacity: 1;
	}
.leaflet-zoom-animated {
	transform-origin: 0 0;
	}
svg.leaflet-zoom-animated {
	will-change: transform;
}
.leaflet-zoom-anim .leaflet-zoom-animated {
	transition:         transform 0.25s cubic-bezier(0,0,0.25,1);
	}
.leaflet-zoom-anim .leaflet-tile,
.leaflet-pan-anim .leaflet-tile {
	transition: none;
	}
.leaflet-zoom-anim .leaflet-zoom-hide {
	visibility: hidden;
	}
/* cursors */
.leaflet-interactive {
	cursor: pointer;
	}
.leaflet-grab {
	cursor:         grab;
	}
.leaflet-crosshair,
.leaflet-crosshair .leaflet-interactive {
	cursor: crosshair;
	}
.leaflet-popup-pane,
.leaflet-control {
	cursor: auto;
	}
.leaflet-dragging .leaflet-grab,
.leaflet-dragging .leaflet-grab .leaflet-interactive,
.leaflet-dragging .leaflet-marker-draggable {
	cursor: move;
	cursor:         grabbing;
	}
/* marker & overlays interactivity */
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-image-layer,
.leaflet-pane > svg path,
.leaflet-tile-container {
	pointer-events: none;
	}
.leaflet-marker-icon.leaflet-interactive,
.leaflet-image-layer.leaflet-interactive,
.leaflet-pane > svg path.leaflet-interactive,
svg.leaflet-image-layer.leaflet-interactive path {
	pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
	pointer-events: auto;
	}
/* visual tweaks */
.leaflet-container {
	background: #ddd;
	outline-offset: 1px;
	}
.leaflet-container a {
	color: #0078A8;
	}
.leaflet-zoom-box {
	border: 2px dotted #38f;
	background: rgba(255,255,255,0.5);
	}
/* general typography */
.leaflet-container {
	font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
	font-size: 12px;
	font-size: 0.75rem;
	line-height: 1.5;
	}
/* general toolbar styles */
.leaflet-bar {
	box-shadow: 0 1px 5px rgba(0,0,0,0.65);
	border-radius: 4px;
	}
.leaflet-bar a {
	background-color: #fff;
	border-bottom: 1px solid #ccc;
	width: 26px;
	height: 26px;
	line-height: 26px;
	display: block;
	text-align: center;
	text-decoration: none;
	color: black;
	}
.leaflet-bar a,
.leaflet-control-layers-toggle {
	background-position: 50% 50%;
	background-repeat: no-repeat;
	display: block;
	}
.leaflet-bar a:hover,
.leaflet-bar a:focus {
	background-color: #f4f4f4;
	}
.leaflet-bar a:first-child {
	border-top-left-radius: 4px;
	border-top-right-radius: 4px;
	}
.leaflet-bar a:last-child {
	border-bottom-left-radius: 4px;
	border-bottom-right-radius: 4px;
	border-bottom: none;
	}
.leaflet-bar a.leaflet-disabled {
	cursor: default;
	background-color: #f4f4f4;
	color: #bbb;
	}
.leaflet-touch .leaflet-bar a {
	width: 30px;
	height: 30px;
	line-height: 30px;
	}
.leaflet-touch .leaflet-bar a:first-child {
	border-top-left-radius: 2px;
	border-top-right-radius: 2px;
	}
.leaflet-touch .leaflet-bar a:last-child {
	border-bottom-left-radius: 2px;
	border-bottom-right-radius: 2px;
	}
/* zoom control */
.leaflet-control-zoom-in,
.leaflet-control-zoom-out {
	font: bold 18px 'Lucida Console', Monaco, monospace;
	text-indent: 1px;
	}
.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out  {
	font-size: 22px;
	}
/* layers control */
.leaflet-control-layers {
	box-shadow: 0 1px 5px rgba(0,0,0,0.4);
	background: #fff;
	border-radius: 5px;
	}
.leaflet-control-layers-toggle {
	background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);
	width: 36px;
	height: 36px;
	}
.leaflet-retina .leaflet-control-layers-toggle {
	background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);
	background-size: 26px 26px;
	}
.leaflet-touch .leaflet-control-layers-toggle {
	width: 44px;
	height: 44px;
	}
.leaflet-control-layers .leaflet-control-layers-list,
.leaflet-control-layers-expanded .leaflet-control-layers-toggle {
	display: none;
	}
.leaflet-control-layers-expanded .leaflet-control-layers-list {
	display: block;
	position: relative;
	}
.leaflet-control-layers-expanded {
	padding: 6px 10px 6px 6px;
	color: #333;
	background: #fff;
	}
.leaflet-control-layers-scrollbar {
	overflow-y: scroll;
	overflow-x: hidden;
	padding-right: 5px;
	}
.leaflet-control-layers-selector {
	margin-top: 2px;
	position: relative;
	top: 1px;
	}
.leaflet-control-layers label {
	display: block;
	font-size: 13px;
	font-size: 1.08333em;
	}
.leaflet-control-layers-separator {
	height: 0;
	border-top: 1px solid #ddd;
	margin: 5px -10px 5px -6px;
	}
/* Default icon URLs */
.leaflet-default-icon-path { /* used only in path-guessing heuristic, see L.Icon.Default */
	background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=);
	}
/* attribution and scale controls */
.leaflet-container .leaflet-control-attribution {
	background: #fff;
	background: rgba(255, 255, 255, 0.8);
	margin: 0;
	}
.leaflet-control-attribution,
.leaflet-control-scale-line {
	padding: 0 5px;
	color: #333;
	line-height: 1.4;
	}
.leaflet-control-attribution a {
	text-decoration: none;
	}
.leaflet-control-attribution a:hover,
.leaflet-control-attribution a:focus {
	text-decoration: underline;
	}
.leaflet-attribution-flag {
	display: inline !important;
	vertical-align: baseline !important;
	width: 1em;
	height: 0.6669em;
	}
.leaflet-left .leaflet-control-scale {
	margin-left: 5px;
	}
.leaflet-bottom .leaflet-control-scale {
	margin-bottom: 5px;
	}
.leaflet-control-scale-line {
	border: 2px solid #777;
	border-top: none;
	line-height: 1.1;
	padding: 2px 5px 1px;
	white-space: nowrap;
	box-sizing: border-box;
	background: rgba(255, 255, 255, 0.8);
	text-shadow: 1px 1px #fff;
	}
.leaflet-control-scale-line:not(:first-child) {
	border-top: 2px solid #777;
	border-bottom: none;
	margin-top: -2px;
	}
.leaflet-control-scale-line:not(:first-child):not(:last-child) {
	border-bottom: 2px solid #777;
	}
.leaflet-touch .leaflet-control-attribution,
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
	box-shadow: none;
	}
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
	border: 2px solid rgba(0,0,0,0.2);
	background-clip: padding-box;
	}
/* popup */
.leaflet-popup {
	position: absolute;
	text-align: center;
	margin-bottom: 20px;
	}
.leaflet-popup-content-wrapper {
	padding: 1px;
	text-align: left;
	border-radius: 12px;
	}
.leaflet-popup-content {
	margin: 13px 24px 13px 20px;
	line-height: 1.3;
	font-size: 13px;
	font-size: 1.08333em;
	min-height: 1px;
	}
.leaflet-popup-content p {
	margin: 17px 0;
	margin: 1.3em 0;
	}
.leaflet-popup-tip-container {
	width: 40px;
	height: 20px;
	position: absolute;
	left: 50%;
	margin-top: -1px;
	margin-left: -20px;
	overflow: hidden;
	pointer-events: none;
	}
.leaflet-popup-tip {
	width: 17px;
	height: 17px;
	padding: 1px;

	margin: -10px auto 0;
	pointer-events: auto;
	transform: rotate(45deg);
	}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
	background: white;
	color: #333;
	box-shadow: 0 3px 14px rgba(0,0,0,0.4);
	}
.leaflet-container a.leaflet-popup-close-button {
	position: absolute;
	top: 0;
	right: 0;
	border: none;
	text-align: center;
	width: 24px;
	height: 24px;
	font: 16px/24px Tahoma, Verdana, sans-serif;
	color: #757575;
	text-decoration: none;
	background: transparent;
	}
.leaflet-container a.leaflet-popup-close-button:hover,
.leaflet-container a.leaflet-popup-close-button:focus {
	color: #585858;
	}
.leaflet-popup-scrolled {
	overflow: auto;
	}
.leaflet-oldie .leaflet-popup-content-wrapper {
	-ms-zoom: 1;
	}
.leaflet-oldie .leaflet-popup-tip {
	width: 24px;
	margin: 0 auto;

	-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
	filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
	}
.leaflet-oldie .leaflet-control-zoom,
.leaflet-oldie .leaflet-control-layers,
.leaflet-oldie .leaflet-popup-content-wrapper,
.leaflet-oldie .leaflet-popup-tip {
	border: 1px solid #999;
	}
/* div icon */
.leaflet-div-icon {
	background: #fff;
	border: 1px solid #666;
	}
/* Tooltip */
/* Base styles for the element that has a tooltip */
.leaflet-tooltip {
	position: absolute;
	padding: 6px;
	background-color: #fff;
	border: 1px solid #fff;
	border-radius: 3px;
	color: #222;
	white-space: nowrap;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	pointer-events: none;
	box-shadow: 0 1px 3px rgba(0,0,0,0.4);
	}
.leaflet-tooltip.leaflet-interactive {
	cursor: pointer;
	pointer-events: auto;
	}
.leaflet-tooltip-top:before,
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
	position: absolute;
	pointer-events: none;
	border: 6px solid transparent;
	background: transparent;
	content: "";
	}
/* Directions */
.leaflet-tooltip-bottom {
	margin-top: 6px;
}
.leaflet-tooltip-top {
	margin-top: -6px;
}
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-top:before {
	left: 50%;
	margin-left: -6px;
	}
.leaflet-tooltip-top:before {
	bottom: 0;
	margin-bottom: -12px;
	border-top-color: #fff;
	}
.leaflet-tooltip-bottom:before {
	top: 0;
	margin-top: -12px;
	margin-left: -6px;
	border-bottom-color: #fff;
	}
.leaflet-tooltip-left {
	margin-left: -6px;
}
.leaflet-tooltip-right {
	margin-left: 6px;
}
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
	top: 50%;
	margin-top: -6px;
	}
.leaflet-tooltip-left:before {
	right: 0;
	margin-right: -12px;
	border-left-color: #fff;
	}
.leaflet-tooltip-right:before {
	left: 0;
	margin-left: -12px;
	border-right-color: #fff;
	}
/* Printing */
@media print {
	/* Prevent printers from removing background-images of controls. */
	.leaflet-control {
		-webkit-print-color-adjust: exact;
		print-color-adjust: exact;
		}
	}
*, ::before, ::after{
	--tw-border-spacing-x: 0;
	--tw-border-spacing-y: 0;
	--tw-translate-x: 0;
	--tw-translate-y: 0;
	--tw-rotate: 0;
	--tw-skew-x: 0;
	--tw-skew-y: 0;
	--tw-scale-x: 1;
	--tw-scale-y: 1;
	--tw-pan-x:  ;
	--tw-pan-y:  ;
	--tw-pinch-zoom:  ;
	--tw-scroll-snap-strictness: proximity;
	--tw-gradient-from-position:  ;
	--tw-gradient-via-position:  ;
	--tw-gradient-to-position:  ;
	--tw-ordinal:  ;
	--tw-slashed-zero:  ;
	--tw-numeric-figure:  ;
	--tw-numeric-spacing:  ;
	--tw-numeric-fraction:  ;
	--tw-ring-inset:  ;
	--tw-ring-offset-width: 0px;
	--tw-ring-offset-color: #fff;
	--tw-ring-color: rgb(59 130 246 / 0.5);
	--tw-ring-offset-shadow: 0 0 #0000;
	--tw-ring-shadow: 0 0 #0000;
	--tw-shadow: 0 0 #0000;
	--tw-shadow-colored: 0 0 #0000;
	--tw-blur:  ;
	--tw-brightness:  ;
	--tw-contrast:  ;
	--tw-grayscale:  ;
	--tw-hue-rotate:  ;
	--tw-invert:  ;
	--tw-saturate:  ;
	--tw-sepia:  ;
	--tw-drop-shadow:  ;
	--tw-backdrop-blur:  ;
	--tw-backdrop-brightness:  ;
	--tw-backdrop-contrast:  ;
	--tw-backdrop-grayscale:  ;
	--tw-backdrop-hue-rotate:  ;
	--tw-backdrop-invert:  ;
	--tw-backdrop-opacity:  ;
	--tw-backdrop-saturate:  ;
	--tw-backdrop-sepia:  ;
	--tw-contain-size:  ;
	--tw-contain-layout:  ;
	--tw-contain-paint:  ;
	--tw-contain-style:  ;
}
::backdrop{
	--tw-border-spacing-x: 0;
	--tw-border-spacing-y: 0;
	--tw-translate-x: 0;
	--tw-translate-y: 0;
	--tw-rotate: 0;
	--tw-skew-x: 0;
	--tw-skew-y: 0;
	--tw-scale-x: 1;
	--tw-scale-y: 1;
	--tw-pan-x:  ;
	--tw-pan-y:  ;
	--tw-pinch-zoom:  ;
	--tw-scroll-snap-strictness: proximity;
	--tw-gradient-from-position:  ;
	--tw-gradient-via-position:  ;
	--tw-gradient-to-position:  ;
	--tw-ordinal:  ;
	--tw-slashed-zero:  ;
	--tw-numeric-figure:  ;
	--tw-numeric-spacing:  ;
	--tw-numeric-fraction:  ;
	--tw-ring-inset:  ;
	--tw-ring-offset-width: 0px;
	--tw-ring-offset-color: #fff;
	--tw-ring-color: rgb(59 130 246 / 0.5);
	--tw-ring-offset-shadow: 0 0 #0000;
	--tw-ring-shadow: 0 0 #0000;
	--tw-shadow: 0 0 #0000;
	--tw-shadow-colored: 0 0 #0000;
	--tw-blur:  ;
	--tw-brightness:  ;
	--tw-contrast:  ;
	--tw-grayscale:  ;
	--tw-hue-rotate:  ;
	--tw-invert:  ;
	--tw-saturate:  ;
	--tw-sepia:  ;
	--tw-drop-shadow:  ;
	--tw-backdrop-blur:  ;
	--tw-backdrop-brightness:  ;
	--tw-backdrop-contrast:  ;
	--tw-backdrop-grayscale:  ;
	--tw-backdrop-hue-rotate:  ;
	--tw-backdrop-invert:  ;
	--tw-backdrop-opacity:  ;
	--tw-backdrop-saturate:  ;
	--tw-backdrop-sepia:  ;
	--tw-contain-size:  ;
	--tw-contain-layout:  ;
	--tw-contain-paint:  ;
	--tw-contain-style:  ;
}
/* ! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com */
/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/
*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}
::before,
::after {
  --tw-content: '';
}
/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/
html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}
/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/
body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}
/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/
hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}
/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/
abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}
/*
Remove the default font size and weight for headings.
*/
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}
/*
Reset links to optimize for opt-in styling instead of opt-out.
*/
a {
  color: inherit;
  text-decoration: inherit;
}
/*
Add the correct font weight in Edge and Safari.
*/
b,
strong {
  font-weight: bolder;
}
/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/
code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}
/*
Add the correct font size in all browsers.
*/
small {
  font-size: 80%;
}
/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/
table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}
/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}
/*
Remove the inheritance of text transform in Edge and Firefox.
*/
button,
select {
  text-transform: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/
button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}
/*
Use the modern Firefox focus style for all focusable elements.
*/
:-moz-focusring {
  outline: auto;
}
/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/
:-moz-ui-invalid {
  box-shadow: none;
}
/*
Add the correct vertical alignment in Chrome and Firefox.
*/
progress {
  vertical-align: baseline;
}
/*
Correct the cursor style of increment and decrement buttons in Safari.
*/
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}
/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/
[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}
/*
Remove the inner padding in Chrome and Safari on macOS.
*/
::-webkit-search-decoration {
  -webkit-appearance: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
/*
Add the correct display in Chrome and Safari.
*/
summary {
  display: list-item;
}
/*
Removes the default spacing and border for appropriate elements.
*/
blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}
fieldset {
  margin: 0;
  padding: 0;
}
legend {
  padding: 0;
}
ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}
/*
Prevent resizing textareas horizontally by default.
*/
textarea {
  resize: vertical;
}
/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/
input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
/*
Set the default cursor for buttons.
*/
button,
[role="button"] {
  cursor: pointer;
}
/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}
/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/
img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}
/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/
img,
video {
  max-width: 100%;
  height: auto;
}
/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}
/* Light mode token values (RGB triplets for Tailwind opacity support) */
:root {
    --bg: #F6F1E7;
    --bg-grad-top: #FBF8F1;
    --bg-grad-bot: #F1EADC;
    --surface: #FFFFFF;
    --surface-2: #FCFAF4;
    --surface-sunken:#EFE8DA;
    --ink: #1B2436;
    --ink-2: #5C6478;
    --ink-3: #939AAA;
    --border: rgba(20,30,55,0.10);
    --border-strong: rgba(20,30,55,0.16);
    --divider: rgba(20,30,55,0.07);
    --gold: #B8923C;
    --gold-text: #8A6D24;
    --gold-tint: #F3E7C9;
    --on-gold: #2C2310;
    --flight-bg:#E6F1FB; --flight-fg:#0C447C; --flight-dot:#185FA5; --flight-edge:#185FA5;
    --stay-bg:#FAEEDA; --stay-fg:#854F0B; --stay-dot:#BA7517; --stay-edge:#BA7517;
    --dining-bg:#FAECE7; --dining-fg:#993C1D; --dining-dot:#D85A30; --dining-edge:#D85A30;
    --transfer-bg:#E1F5EE; --transfer-fg:#0F6E56; --transfer-dot:#0F6E56; --transfer-edge:#0F6E56;
    --activity-bg:#EEEDFE; --activity-fg:#3C3489; --activity-dot:#534AB7; --activity-edge:#534AB7;
    --danger:#A32D2D;
    --danger-bg:#FCEBEB;
    --success:#1D9E75;
    --shadow-card: 0 1px 2px rgba(20,30,55,.04), 0 8px 24px rgba(20,30,55,.06);
    --shadow-focal: 0 2px 6px rgba(20,30,55,.06), 0 16px 40px rgba(20,30,55,.10);
    --grain-opacity:.035;
    --star-opacity:0;
    --r-sm:10px; --r-md:14px; --r-lg:18px; --r-xl:24px; --r-pill:999px;
    --font-serif:'Playfair Display', Georgia, 'Times New Roman', serif;
    --font-sans:'Hanken Grotesk', system-ui, -apple-system, sans-serif;
    --c-bg: 246 241 231;
    --c-card: 255 255 255;
    --c-ink: 27 36 54;
    --c-ink-soft: 92 100 120;
    --c-ink-faint: 147 154 170;
    --c-gold: 184 146 60;
    --line: var(--divider);
  }
/* Dark mode overrides */
.dark,
  [data-theme="dark"] {
    --bg:#0B0E15;
    --bg-grad-top:#10141F;
    --bg-grad-bot:#070910;
    --surface:#121A2A;
    --surface-2:#0F1623;
    --surface-sunken:#0C121E;
    --ink:#F3F0E9;
    --ink-2:#9AA0AD;
    --ink-3:#6A7180;
    --border:rgba(255,255,255,0.09);
    --border-strong:rgba(255,255,255,0.16);
    --divider:rgba(255,255,255,0.06);
    --gold:#D8B45C;
    --gold-text:#E7C877;
    --gold-tint:rgba(216,180,92,0.12);
    --on-gold:#2C2310;
    --flight-bg:#11233A; --flight-fg:#B5D4F4; --flight-dot:#378ADD; --flight-edge:#378ADD;
    --stay-bg:#2A1E0A; --stay-fg:#FAC775; --stay-dot:#EF9F27; --stay-edge:#EF9F27;
    --dining-bg:#2E170F; --dining-fg:#F0997B; --dining-dot:#D85A30; --dining-edge:#D85A30;
    --transfer-bg:#0A241D; --transfer-fg:#5DCAA5; --transfer-dot:#1D9E75; --transfer-edge:#1D9E75;
    --activity-bg:#1A1736; --activity-fg:#AFA9EC; --activity-dot:#7F77DD; --activity-edge:#7F77DD;
    --danger:#F09595;
    --danger-bg:#2A1313;
    --success:#5DCAA5;
    --shadow-card:0 1px 2px rgba(0,0,0,.4), 0 10px 30px rgba(0,0,0,.45);
    --shadow-focal:0 2px 8px rgba(0,0,0,.45), 0 18px 48px rgba(0,0,0,.55);
    --grain-opacity:.05;
    --star-opacity:.55;
    --c-bg: 11 14 21;
    --c-card: 18 26 42;
    --c-ink: 243 240 233;
    --c-ink-soft: 154 160 173;
    --c-ink-faint: 106 113 128;
    --c-gold: 216 180 92;
    --line: var(--divider);
  }
*, *::before, *::after {
    box-sizing: border-box;
  }
body{
	--tw-bg-opacity: 1;
	background-color: rgb(var(--c-bg) / var(--tw-bg-opacity, 1));
	font-family: DM Sans, system-ui, sans-serif;
	--tw-text-opacity: 1;
	color: rgb(var(--c-ink) / var(--tw-text-opacity, 1));
    font-family: var(--font-sans);
    background:
      radial-gradient(120% 80% at 50% -10%, rgba(184,146,60,.05), transparent 60%),
      linear-gradient(180deg, var(--bg-grad-top), var(--bg-grad-bot));
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin: 0;
}
[data-theme="dark"] body {
    background:
      radial-gradient(120% 80% at 50% -10%, rgba(216,180,92,.06), transparent 60%),
      linear-gradient(180deg, var(--bg-grad-top), var(--bg-grad-bot));
  }
#root {
    min-height: 100svh;
  }
.pointer-events-none{
	pointer-events: none;
}
.pointer-events-auto{
	pointer-events: auto;
}
.\!visible{
	visibility: visible !important;
}
.visible{
	visibility: visible;
}
.fixed{
	position: fixed;
}
.absolute{
	position: absolute;
}
.relative{
	position: relative;
}
.sticky{
	position: sticky;
}
.inset-0{
	inset: 0px;
}
.inset-x-3{
	left: 0.75rem;
	right: 0.75rem;
}
.inset-x-4{
	left: 1rem;
	right: 1rem;
}
.inset-x-5{
	left: 1.25rem;
	right: 1.25rem;
}
.-right-1{
	right: -0.25rem;
}
.-right-7{
	right: -1.75rem;
}
.-top-1{
	top: -0.25rem;
}
.-top-2{
	top: -0.5rem;
}
.bottom-0{
	bottom: 0px;
}
.bottom-1{
	bottom: 0.25rem;
}
.bottom-1\.5{
	bottom: 0.375rem;
}
.bottom-24{
	bottom: 6rem;
}
.bottom-28{
	bottom: 7rem;
}
.bottom-3{
	bottom: 0.75rem;
}
.bottom-4{
	bottom: 1rem;
}
.bottom-full{
	bottom: 100%;
}
.left-0{
	left: 0px;
}
.left-1{
	left: 0.25rem;
}
.left-1\/2{
	left: 50%;
}
.left-2{
	left: 0.5rem;
}
.left-3{
	left: 0.75rem;
}
.left-3\.5{
	left: 0.875rem;
}
.left-4{
	left: 1rem;
}
.right-0{
	right: 0px;
}
.right-1\.5{
	right: 0.375rem;
}
.right-2{
	right: 0.5rem;
}
.right-20{
	right: 5rem;
}
.right-3{
	right: 0.75rem;
}
.right-4{
	right: 1rem;
}
.right-full{
	right: 100%;
}
.top-0{
	top: 0px;
}
.top-1\.5{
	top: 0.375rem;
}
.top-1\/2{
	top: 50%;
}
.top-14{
	top: 3.5rem;
}
.top-2{
	top: 0.5rem;
}
.top-3{
	top: 0.75rem;
}
.top-4{
	top: 1rem;
}
.top-\[104px\]{
	top: 104px;
}
.top-\[2px\]{
	top: 2px;
}
.top-full{
	top: 100%;
}
.z-10{
	z-index: 10;
}
.z-20{
	z-index: 20;
}
.z-50{
	z-index: 50;
}
.z-\[1200\]{
	z-index: 1200;
}
.z-\[300\]{
	z-index: 300;
}
.z-\[400\]{
	z-index: 400;
}
.z-\[450\]{
	z-index: 450;
}
.z-\[500\]{
	z-index: 500;
}
.z-\[790\]{
	z-index: 790;
}
.z-\[820\]{
	z-index: 820;
}
.z-\[850\]{
	z-index: 850;
}
.z-\[860\]{
	z-index: 860;
}
.z-\[870\]{
	z-index: 870;
}
.z-\[880\]{
	z-index: 880;
}
.z-\[890\]{
	z-index: 890;
}
.z-\[900\]{
	z-index: 900;
}
.z-\[905\]{
	z-index: 905;
}
.z-\[910\]{
	z-index: 910;
}
.z-\[920\]{
	z-index: 920;
}
.z-\[930\]{
	z-index: 930;
}
.z-\[950\]{
	z-index: 950;
}
.-mx-5{
	margin-left: -1.25rem;
	margin-right: -1.25rem;
}
.mx-0{
	margin-left: 0px;
	margin-right: 0px;
}
.mx-4{
	margin-left: 1rem;
	margin-right: 1rem;
}
.mx-auto{
	margin-left: auto;
	margin-right: auto;
}
.my-2{
	margin-top: 0.5rem;
	margin-bottom: 0.5rem;
}
.my-4{
	margin-top: 1rem;
	margin-bottom: 1rem;
}
.my-5{
	margin-top: 1.25rem;
	margin-bottom: 1.25rem;
}
.my-7{
	margin-top: 1.75rem;
	margin-bottom: 1.75rem;
}
.-mb-px{
	margin-bottom: -1px;
}
.-ml-1{
	margin-left: -0.25rem;
}
.-mt-1{
	margin-top: -0.25rem;
}
.mb-0{
	margin-bottom: 0px;
}
.mb-1{
	margin-bottom: 0.25rem;
}
.mb-1\.5{
	margin-bottom: 0.375rem;
}
.mb-2{
	margin-bottom: 0.5rem;
}
.mb-3{
	margin-bottom: 0.75rem;
}
.mb-4{
	margin-bottom: 1rem;
}
.mb-5{
	margin-bottom: 1.25rem;
}
.mb-6{
	margin-bottom: 1.5rem;
}
.mb-8{
	margin-bottom: 2rem;
}
.ml-2{
	margin-left: 0.5rem;
}
.ml-auto{
	margin-left: auto;
}
.mr-1{
	margin-right: 0.25rem;
}
.mr-2{
	margin-right: 0.5rem;
}
.mt-0\.5{
	margin-top: 0.125rem;
}
.mt-1{
	margin-top: 0.25rem;
}
.mt-1\.5{
	margin-top: 0.375rem;
}
.mt-10{
	margin-top: 2.5rem;
}
.mt-2{
	margin-top: 0.5rem;
}
.mt-3{
	margin-top: 0.75rem;
}
.mt-4{
	margin-top: 1rem;
}
.mt-5{
	margin-top: 1.25rem;
}
.mt-6{
	margin-top: 1.5rem;
}
.mt-7{
	margin-top: 1.75rem;
}
.mt-8{
	margin-top: 2rem;
}
.mt-\[14px\]{
	margin-top: 14px;
}
.line-clamp-1{
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
}
.line-clamp-2{
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}
.line-clamp-3{
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}
.\!block{
	display: block !important;
}
.block{
	display: block;
}
.inline-block{
	display: inline-block;
}
.inline{
	display: inline;
}
.flex{
	display: flex;
}
.inline-flex{
	display: inline-flex;
}
.grid{
	display: grid;
}
.hidden{
	display: none;
}
.aspect-square{
	aspect-ratio: 1 / 1;
}
.h-1{
	height: 0.25rem;
}
.h-1\.5{
	height: 0.375rem;
}
.h-10{
	height: 2.5rem;
}
.h-11{
	height: 2.75rem;
}
.h-12{
	height: 3rem;
}
.h-14{
	height: 3.5rem;
}
.h-16{
	height: 4rem;
}
.h-2{
	height: 0.5rem;
}
.h-2\.5{
	height: 0.625rem;
}
.h-20{
	height: 5rem;
}
.h-24{
	height: 6rem;
}
.h-3{
	height: 0.75rem;
}
.h-32{
	height: 8rem;
}
.h-4{
	height: 1rem;
}
.h-40{
	height: 10rem;
}
.h-44{
	height: 11rem;
}
.h-48{
	height: 12rem;
}
.h-5{
	height: 1.25rem;
}
.h-6{
	height: 1.5rem;
}
.h-64{
	height: 16rem;
}
.h-7{
	height: 1.75rem;
}
.h-8{
	height: 2rem;
}
.h-9{
	height: 2.25rem;
}
.h-\[120px\]{
	height: 120px;
}
.h-\[140px\]{
	height: 140px;
}
.h-\[170px\]{
	height: 170px;
}
.h-\[18px\]{
	height: 18px;
}
.h-\[190px\]{
	height: 190px;
}
.h-\[22px\]{
	height: 22px;
}
.h-\[360px\]{
	height: 360px;
}
.h-\[40px\]{
	height: 40px;
}
.h-\[48px\]{
	height: 48px;
}
.h-\[58px\]{
	height: 58px;
}
.h-\[64px\]{
	height: 64px;
}
.h-\[80px\]{
	height: 80px;
}
.h-\[calc\(100\%-116px\)\]{
	height: calc(100% - 116px);
}
.h-\[calc\(100vh-190px\)\]{
	height: calc(100vh - 190px);
}
.h-auto{
	height: auto;
}
.h-full{
	height: 100%;
}
.h-px{
	height: 1px;
}
.max-h-28{
	max-height: 7rem;
}
.max-h-48{
	max-height: 12rem;
}
.max-h-52{
	max-height: 13rem;
}
.max-h-\[70vh\]{
	max-height: 70vh;
}
.max-h-\[75vh\]{
	max-height: 75vh;
}
.max-h-\[80vh\]{
	max-height: 80vh;
}
.max-h-\[82vh\]{
	max-height: 82vh;
}
.max-h-\[86vh\]{
	max-height: 86vh;
}
.max-h-\[88vh\]{
	max-height: 88vh;
}
.max-h-full{
	max-height: 100%;
}
.min-h-0{
	min-height: 0px;
}
.min-h-11{
	min-height: 2.75rem;
}
.min-h-9{
	min-height: 2.25rem;
}
.min-h-\[118px\]{
	min-height: 118px;
}
.min-h-\[120px\]{
	min-height: 120px;
}
.min-h-\[150px\]{
	min-height: 150px;
}
.min-h-\[220px\]{
	min-height: 220px;
}
.min-h-\[520px\]{
	min-height: 520px;
}
.min-h-\[55vh\]{
	min-height: 55vh;
}
.min-h-\[60vh\]{
	min-height: 60vh;
}
.min-h-\[70vh\]{
	min-height: 70vh;
}
.min-h-full{
	min-height: 100%;
}
.min-h-screen{
	min-height: 100vh;
}
.w-0\.5{
	width: 0.125rem;
}
.w-1{
	width: 0.25rem;
}
.w-1\.5{
	width: 0.375rem;
}
.w-10{
	width: 2.5rem;
}
.w-11{
	width: 2.75rem;
}
.w-12{
	width: 3rem;
}
.w-14{
	width: 3.5rem;
}
.w-16{
	width: 4rem;
}
.w-2{
	width: 0.5rem;
}
.w-2\.5{
	width: 0.625rem;
}
.w-20{
	width: 5rem;
}
.w-24{
	width: 6rem;
}
.w-3{
	width: 0.75rem;
}
.w-4{
	width: 1rem;
}
.w-5{
	width: 1.25rem;
}
.w-6{
	width: 1.5rem;
}
.w-7{
	width: 1.75rem;
}
.w-8{
	width: 2rem;
}
.w-9{
	width: 2.25rem;
}
.w-\[108px\]{
	width: 108px;
}
.w-\[154px\]{
	width: 154px;
}
.w-\[18px\]{
	width: 18px;
}
.w-\[220px\]{
	width: 220px;
}
.w-\[38px\]{
	width: 38px;
}
.w-\[3px\]{
	width: 3px;
}
.w-\[40px\]{
	width: 40px;
}
.w-\[48px\]{
	width: 48px;
}
.w-\[60px\]{
	width: 60px;
}
.w-\[68px\]{
	width: 68px;
}
.w-\[72px\]{
	width: 72px;
}
.w-\[80px\]{
	width: 80px;
}
.w-\[min\(94vw\2c 430px\)\]{
	width: min(94vw, 430px);
}
.w-full{
	width: 100%;
}
.w-px{
	width: 1px;
}
.min-w-0{
	min-width: 0px;
}
.max-w-\[220px\]{
	max-width: 220px;
}
.max-w-\[230px\]{
	max-width: 230px;
}
.max-w-\[300px\]{
	max-width: 300px;
}
.max-w-\[360px\]{
	max-width: 360px;
}
.max-w-\[380px\]{
	max-width: 380px;
}
.max-w-\[390px\]{
	max-width: 390px;
}
.max-w-\[460px\]{
	max-width: 460px;
}
.max-w-\[720px\]{
	max-width: 720px;
}
.max-w-\[82\%\]{
	max-width: 82%;
}
.max-w-full{
	max-width: 100%;
}
.max-w-lg{
	max-width: 32rem;
}
.max-w-none{
	max-width: none;
}
.max-w-sm{
	max-width: 24rem;
}
.max-w-xs{
	max-width: 20rem;
}
.flex-1{
	flex: 1 1 0%;
}
.flex-shrink-0{
	flex-shrink: 0;
}
.shrink-0{
	flex-shrink: 0;
}
.-translate-x-1\/2{
	--tw-translate-x: -50%;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.-translate-y-1\/2{
	--tw-translate-y: -50%;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.translate-x-0\.5{
	--tw-translate-x: 0.125rem;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.translate-x-5{
	--tw-translate-x: 1.25rem;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.translate-x-\[14px\]{
	--tw-translate-x: 14px;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.translate-x-\[18px\]{
	--tw-translate-x: 18px;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.translate-x-\[2px\]{
	--tw-translate-x: 2px;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.transform{
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.animate-\[slideDown_220ms_ease-out\]{
	animation: slideDown 220ms ease-out;
}
@keyframes bounce{
	0%, 100%{
		transform: translateY(-25%);
		animation-timing-function: cubic-bezier(0.8,0,1,1);
	}
	50%{
		transform: none;
		animation-timing-function: cubic-bezier(0,0,0.2,1);
	}
}
.animate-bounce{
	animation: bounce 1s infinite;
}
@keyframes pulse{
	50%{
		opacity: .5;
	}
}
.animate-pulse{
	animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
@keyframes spin{
	to{
		transform: rotate(360deg);
	}
}
.animate-spin{
	animation: spin 1s linear infinite;
}
.cursor-not-allowed{
	cursor: not-allowed;
}
.cursor-pointer{
	cursor: pointer;
}
.select-none{
	-webkit-user-select: none;
	   -moz-user-select: none;
	        user-select: none;
}
.resize-none{
	resize: none;
}
.resize{
	resize: both;
}
.list-disc{
	list-style-type: disc;
}
.grid-cols-1{
	grid-template-columns: repeat(1, minmax(0, 1fr));
}
.grid-cols-2{
	grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid-cols-3{
	grid-template-columns: repeat(3, minmax(0, 1fr));
}
.flex-col{
	flex-direction: column;
}
.flex-wrap{
	flex-wrap: wrap;
}
.items-start{
	align-items: flex-start;
}
.items-end{
	align-items: flex-end;
}
.items-center{
	align-items: center;
}
.items-baseline{
	align-items: baseline;
}
.justify-start{
	justify-content: flex-start;
}
.justify-end{
	justify-content: flex-end;
}
.justify-center{
	justify-content: center;
}
.justify-between{
	justify-content: space-between;
}
.justify-around{
	justify-content: space-around;
}
.gap-0{
	gap: 0px;
}
.gap-0\.5{
	gap: 0.125rem;
}
.gap-1{
	gap: 0.25rem;
}
.gap-1\.5{
	gap: 0.375rem;
}
.gap-2{
	gap: 0.5rem;
}
.gap-2\.5{
	gap: 0.625rem;
}
.gap-3{
	gap: 0.75rem;
}
.gap-4{
	gap: 1rem;
}
.gap-5{
	gap: 1.25rem;
}
.gap-6{
	gap: 1.5rem;
}
.gap-\[10px\]{
	gap: 10px;
}
.gap-px{
	gap: 1px;
}
.gap-x-2{
	-moz-column-gap: 0.5rem;
	     column-gap: 0.5rem;
}
.gap-y-0\.5{
	row-gap: 0.125rem;
}
.-space-x-2 > :not([hidden]) ~ :not([hidden]){
	--tw-space-x-reverse: 0;
	margin-right: calc(-0.5rem * var(--tw-space-x-reverse));
	margin-left: calc(-0.5rem * calc(1 - var(--tw-space-x-reverse)));
}
.space-y-0\.5 > :not([hidden]) ~ :not([hidden]){
	--tw-space-y-reverse: 0;
	margin-top: calc(0.125rem * calc(1 - var(--tw-space-y-reverse)));
	margin-bottom: calc(0.125rem * var(--tw-space-y-reverse));
}
.space-y-1 > :not([hidden]) ~ :not([hidden]){
	--tw-space-y-reverse: 0;
	margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse)));
	margin-bottom: calc(0.25rem * var(--tw-space-y-reverse));
}
.space-y-1\.5 > :not([hidden]) ~ :not([hidden]){
	--tw-space-y-reverse: 0;
	margin-top: calc(0.375rem * calc(1 - var(--tw-space-y-reverse)));
	margin-bottom: calc(0.375rem * var(--tw-space-y-reverse));
}
.space-y-2 > :not([hidden]) ~ :not([hidden]){
	--tw-space-y-reverse: 0;
	margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
	margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
}
.space-y-3 > :not([hidden]) ~ :not([hidden]){
	--tw-space-y-reverse: 0;
	margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
	margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
}
.space-y-4 > :not([hidden]) ~ :not([hidden]){
	--tw-space-y-reverse: 0;
	margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
	margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}
.space-y-5 > :not([hidden]) ~ :not([hidden]){
	--tw-space-y-reverse: 0;
	margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
	margin-bottom: calc(1.25rem * var(--tw-space-y-reverse));
}
.space-y-6 > :not([hidden]) ~ :not([hidden]){
	--tw-space-y-reverse: 0;
	margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
	margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}
.self-center{
	align-self: center;
}
.overflow-hidden{
	overflow: hidden;
}
.overflow-x-auto{
	overflow-x: auto;
}
.overflow-y-auto{
	overflow-y: auto;
}
.overscroll-x-contain{
	overscroll-behavior-x: contain;
}
.truncate{
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.whitespace-nowrap{
	white-space: nowrap;
}
.whitespace-pre-wrap{
	white-space: pre-wrap;
}
.break-words{
	overflow-wrap: break-word;
}
.break-all{
	word-break: break-all;
}
.rounded{
	border-radius: 0.25rem;
}
.rounded-2xl{
	border-radius: 1rem;
}
.rounded-card{
	border-radius: 0.875rem;
}
.rounded-full{
	border-radius: 9999px;
}
.rounded-lg{
	border-radius: 0.5rem;
}
.rounded-md{
	border-radius: 0.375rem;
}
.rounded-none{
	border-radius: 0px;
}
.rounded-xl{
	border-radius: 0.75rem;
}
.rounded-t-2xl{
	border-top-left-radius: 1rem;
	border-top-right-radius: 1rem;
}
.border{
	border-width: 1px;
}
.border-2{
	border-width: 2px;
}
.border-4{
	border-width: 4px;
}
.border-b{
	border-bottom-width: 1px;
}
.border-b-2{
	border-bottom-width: 2px;
}
.border-l{
	border-left-width: 1px;
}
.border-l-2{
	border-left-width: 2px;
}
.border-r{
	border-right-width: 1px;
}
.border-t{
	border-top-width: 1px;
}
.border-dashed{
	border-style: dashed;
}
.border-\[var\(--border\)\]{
	border-color: var(--border);
}
.border-amber-200{
	--tw-border-opacity: 1;
	border-color: rgb(253 230 138 / var(--tw-border-opacity, 1));
}
.border-amber-300\/70{
	border-color: rgb(252 211 77 / 0.7);
}
.border-card{
	--tw-border-opacity: 1;
	border-color: rgb(var(--c-card) / var(--tw-border-opacity, 1));
}
.border-emerald-400{
	--tw-border-opacity: 1;
	border-color: rgb(52 211 153 / var(--tw-border-opacity, 1));
}
.border-gold{
	--tw-border-opacity: 1;
	border-color: rgb(var(--c-gold) / var(--tw-border-opacity, 1));
}
.border-gold\/15{
	border-color: rgb(var(--c-gold) / 0.15);
}
.border-gold\/20{
	border-color: rgb(var(--c-gold) / 0.2);
}
.border-gold\/25{
	border-color: rgb(var(--c-gold) / 0.25);
}
.border-gold\/30{
	border-color: rgb(var(--c-gold) / 0.3);
}
.border-gold\/45{
	border-color: rgb(var(--c-gold) / 0.45);
}
.border-gold\/50{
	border-color: rgb(var(--c-gold) / 0.5);
}
.border-gold\/60{
	border-color: rgb(var(--c-gold) / 0.6);
}
.border-ink\/10{
	border-color: rgb(var(--c-ink) / 0.1);
}
.border-ink\/15{
	border-color: rgb(var(--c-ink) / 0.15);
}
.border-ink\/20{
	border-color: rgb(var(--c-ink) / 0.2);
}
.border-ink\/30{
	border-color: rgb(var(--c-ink) / 0.3);
}
.border-ink\/5{
	border-color: rgb(var(--c-ink) / 0.05);
}
.border-line{
	border-color: rgb(var(--c-ink) / 0.08);
}
.border-red-200{
	--tw-border-opacity: 1;
	border-color: rgb(254 202 202 / var(--tw-border-opacity, 1));
}
.border-red-400{
	--tw-border-opacity: 1;
	border-color: rgb(248 113 113 / var(--tw-border-opacity, 1));
}
.border-red-400\/30{
	border-color: rgb(248 113 113 / 0.3);
}
.border-transparent{
	border-color: transparent;
}
.border-white{
	--tw-border-opacity: 1;
	border-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
}
.border-white\/10{
	border-color: rgb(255 255 255 / 0.1);
}
.border-white\/40{
	border-color: rgb(255 255 255 / 0.4);
}
.border-white\/60{
	border-color: rgb(255 255 255 / 0.6);
}
.border-t-gold{
	--tw-border-opacity: 1;
	border-top-color: rgb(var(--c-gold) / var(--tw-border-opacity, 1));
}
.border-t-transparent{
	border-top-color: transparent;
}
.border-t-white{
	--tw-border-opacity: 1;
	border-top-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
}
.bg-\[\#1C1C1C\]{
	--tw-bg-opacity: 1;
	background-color: rgb(28 28 28 / var(--tw-bg-opacity, 1));
}
.bg-\[\#4CAF8A\]{
	--tw-bg-opacity: 1;
	background-color: rgb(76 175 138 / var(--tw-bg-opacity, 1));
}
.bg-\[\#E87070\]{
	--tw-bg-opacity: 1;
	background-color: rgb(232 112 112 / var(--tw-bg-opacity, 1));
}
.bg-\[\#FFD100\]{
	--tw-bg-opacity: 1;
	background-color: rgb(255 209 0 / var(--tw-bg-opacity, 1));
}
.bg-\[var\(--gold\)\]{
	background-color: var(--gold);
}
.bg-\[var\(--surface\)\]{
	background-color: var(--surface);
}
.bg-\[var\(--surface-sunken\)\]{
	background-color: var(--surface-sunken);
}
.bg-amber-50{
	--tw-bg-opacity: 1;
	background-color: rgb(255 251 235 / var(--tw-bg-opacity, 1));
}
.bg-bg{
	--tw-bg-opacity: 1;
	background-color: rgb(var(--c-bg) / var(--tw-bg-opacity, 1));
}
.bg-bg\/60{
	background-color: rgb(var(--c-bg) / 0.6);
}
.bg-bg\/95{
	background-color: rgb(var(--c-bg) / 0.95);
}
.bg-black\/30{
	background-color: rgb(0 0 0 / 0.3);
}
.bg-black\/35{
	background-color: rgb(0 0 0 / 0.35);
}
.bg-black\/40{
	background-color: rgb(0 0 0 / 0.4);
}
.bg-black\/45{
	background-color: rgb(0 0 0 / 0.45);
}
.bg-black\/50{
	background-color: rgb(0 0 0 / 0.5);
}
.bg-black\/55{
	background-color: rgb(0 0 0 / 0.55);
}
.bg-black\/60{
	background-color: rgb(0 0 0 / 0.6);
}
.bg-black\/90{
	background-color: rgb(0 0 0 / 0.9);
}
.bg-black\/95{
	background-color: rgb(0 0 0 / 0.95);
}
.bg-card{
	--tw-bg-opacity: 1;
	background-color: rgb(var(--c-card) / var(--tw-bg-opacity, 1));
}
.bg-card\/95{
	background-color: rgb(var(--c-card) / 0.95);
}
.bg-emerald-50{
	--tw-bg-opacity: 1;
	background-color: rgb(236 253 245 / var(--tw-bg-opacity, 1));
}
.bg-emerald-500\/10{
	background-color: rgb(16 185 129 / 0.1);
}
.bg-emerald-500\/80{
	background-color: rgb(16 185 129 / 0.8);
}
.bg-gold{
	--tw-bg-opacity: 1;
	background-color: rgb(var(--c-gold) / var(--tw-bg-opacity, 1));
}
.bg-gold\/10{
	background-color: rgb(var(--c-gold) / 0.1);
}
.bg-gold\/20{
	background-color: rgb(var(--c-gold) / 0.2);
}
.bg-gold\/30{
	background-color: rgb(var(--c-gold) / 0.3);
}
.bg-gold\/40{
	background-color: rgb(var(--c-gold) / 0.4);
}
.bg-gold\/5{
	background-color: rgb(var(--c-gold) / 0.05);
}
.bg-gold\/70{
	background-color: rgb(var(--c-gold) / 0.7);
}
.bg-gray-100{
	--tw-bg-opacity: 1;
	background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}
.bg-gray-400{
	--tw-bg-opacity: 1;
	background-color: rgb(156 163 175 / var(--tw-bg-opacity, 1));
}
.bg-ink{
	--tw-bg-opacity: 1;
	background-color: rgb(var(--c-ink) / var(--tw-bg-opacity, 1));
}
.bg-ink-faint{
	--tw-bg-opacity: 1;
	background-color: rgb(var(--c-ink-faint) / var(--tw-bg-opacity, 1));
}
.bg-ink\/10{
	background-color: rgb(var(--c-ink) / 0.1);
}
.bg-ink\/15{
	background-color: rgb(var(--c-ink) / 0.15);
}
.bg-ink\/20{
	background-color: rgb(var(--c-ink) / 0.2);
}
.bg-ink\/30{
	background-color: rgb(var(--c-ink) / 0.3);
}
.bg-ink\/35{
	background-color: rgb(var(--c-ink) / 0.35);
}
.bg-ink\/5{
	background-color: rgb(var(--c-ink) / 0.05);
}
.bg-ink\/65{
	background-color: rgb(var(--c-ink) / 0.65);
}
.bg-line{
	background-color: rgb(var(--c-ink) / 0.08);
}
.bg-red-50{
	--tw-bg-opacity: 1;
	background-color: rgb(254 242 242 / var(--tw-bg-opacity, 1));
}
.bg-red-500{
	--tw-bg-opacity: 1;
	background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}
.bg-red-500\/10{
	background-color: rgb(239 68 68 / 0.1);
}
.bg-red-500\/80{
	background-color: rgb(239 68 68 / 0.8);
}
.bg-transparent{
	background-color: transparent;
}
.bg-type-activity{
	--tw-bg-opacity: 1;
	background-color: rgb(61 155 155 / var(--tw-bg-opacity, 1));
}
.bg-type-attraction{
	--tw-bg-opacity: 1;
	background-color: rgb(91 155 111 / var(--tw-bg-opacity, 1));
}
.bg-type-concert{
	--tw-bg-opacity: 1;
	background-color: rgb(138 95 168 / var(--tw-bg-opacity, 1));
}
.bg-type-ferry{
	--tw-bg-opacity: 1;
	background-color: rgb(74 144 168 / var(--tw-bg-opacity, 1));
}
.bg-type-flight{
	--tw-bg-opacity: 1;
	background-color: rgb(74 123 168 / var(--tw-bg-opacity, 1));
}
.bg-type-hotel{
	--tw-bg-opacity: 1;
	background-color: rgb(201 168 76 / var(--tw-bg-opacity, 1));
}
.bg-type-other{
	--tw-bg-opacity: 1;
	background-color: rgb(154 163 181 / var(--tw-bg-opacity, 1));
}
.bg-type-restaurant{
	--tw-bg-opacity: 1;
	background-color: rgb(200 90 61 / var(--tw-bg-opacity, 1));
}
.bg-type-transport{
	--tw-bg-opacity: 1;
	background-color: rgb(122 132 153 / var(--tw-bg-opacity, 1));
}
.bg-white{
	--tw-bg-opacity: 1;
	background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.bg-white\/10{
	background-color: rgb(255 255 255 / 0.1);
}
.bg-white\/20{
	background-color: rgb(255 255 255 / 0.2);
}
.bg-white\/25{
	background-color: rgb(255 255 255 / 0.25);
}
.bg-white\/90{
	background-color: rgb(255 255 255 / 0.9);
}
.bg-gradient-to-br{
	background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
}
.from-gold\/15{
	--tw-gradient-from: rgb(var(--c-gold) / 0.15) var(--tw-gradient-from-position);
	--tw-gradient-to: rgb(var(--c-gold) / 0) var(--tw-gradient-to-position);
	--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.via-white\/50{
	--tw-gradient-to: rgb(255 255 255 / 0)  var(--tw-gradient-to-position);
	--tw-gradient-stops: var(--tw-gradient-from), rgb(255 255 255 / 0.5) var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.to-ink\/5{
	--tw-gradient-to: rgb(var(--c-ink) / 0.05) var(--tw-gradient-to-position);
}
.object-contain{
	-o-object-fit: contain;
	   object-fit: contain;
}
.object-cover{
	-o-object-fit: cover;
	   object-fit: cover;
}
.p-1{
	padding: 0.25rem;
}
.p-3{
	padding: 0.75rem;
}
.p-4{
	padding: 1rem;
}
.p-5{
	padding: 1.25rem;
}
.p-6{
	padding: 1.5rem;
}
.px-1{
	padding-left: 0.25rem;
	padding-right: 0.25rem;
}
.px-1\.5{
	padding-left: 0.375rem;
	padding-right: 0.375rem;
}
.px-10{
	padding-left: 2.5rem;
	padding-right: 2.5rem;
}
.px-2{
	padding-left: 0.5rem;
	padding-right: 0.5rem;
}
.px-2\.5{
	padding-left: 0.625rem;
	padding-right: 0.625rem;
}
.px-3{
	padding-left: 0.75rem;
	padding-right: 0.75rem;
}
.px-3\.5{
	padding-left: 0.875rem;
	padding-right: 0.875rem;
}
.px-4{
	padding-left: 1rem;
	padding-right: 1rem;
}
.px-5{
	padding-left: 1.25rem;
	padding-right: 1.25rem;
}
.px-6{
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}
.px-8{
	padding-left: 2rem;
	padding-right: 2rem;
}
.py-0\.5{
	padding-top: 0.125rem;
	padding-bottom: 0.125rem;
}
.py-1{
	padding-top: 0.25rem;
	padding-bottom: 0.25rem;
}
.py-1\.5{
	padding-top: 0.375rem;
	padding-bottom: 0.375rem;
}
.py-10{
	padding-top: 2.5rem;
	padding-bottom: 2.5rem;
}
.py-12{
	padding-top: 3rem;
	padding-bottom: 3rem;
}
.py-16{
	padding-top: 4rem;
	padding-bottom: 4rem;
}
.py-2{
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}
.py-2\.5{
	padding-top: 0.625rem;
	padding-bottom: 0.625rem;
}
.py-3{
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
}
.py-3\.5{
	padding-top: 0.875rem;
	padding-bottom: 0.875rem;
}
.py-4{
	padding-top: 1rem;
	padding-bottom: 1rem;
}
.py-5{
	padding-top: 1.25rem;
	padding-bottom: 1.25rem;
}
.py-6{
	padding-top: 1.5rem;
	padding-bottom: 1.5rem;
}
.py-8{
	padding-top: 2rem;
	padding-bottom: 2rem;
}
.pb-1{
	padding-bottom: 0.25rem;
}
.pb-10{
	padding-bottom: 2.5rem;
}
.pb-12{
	padding-bottom: 3rem;
}
.pb-2{
	padding-bottom: 0.5rem;
}
.pb-28{
	padding-bottom: 7rem;
}
.pb-3{
	padding-bottom: 0.75rem;
}
.pb-32{
	padding-bottom: 8rem;
}
.pb-4{
	padding-bottom: 1rem;
}
.pb-5{
	padding-bottom: 1.25rem;
}
.pb-6{
	padding-bottom: 1.5rem;
}
.pb-7{
	padding-bottom: 1.75rem;
}
.pb-8{
	padding-bottom: 2rem;
}
.pb-\[calc\(1rem\+env\(safe-area-inset-bottom\2c 0px\)\)\]{
	padding-bottom: calc(1rem + env(safe-area-inset-bottom,0px));
}
.pl-10{
	padding-left: 2.5rem;
}
.pl-3{
	padding-left: 0.75rem;
}
.pl-4{
	padding-left: 1rem;
}
.pl-5{
	padding-left: 1.25rem;
}
.pl-7{
	padding-left: 1.75rem;
}
.pr-1{
	padding-right: 0.25rem;
}
.pr-11{
	padding-right: 2.75rem;
}
.pr-12{
	padding-right: 3rem;
}
.pr-2{
	padding-right: 0.5rem;
}
.pr-3{
	padding-right: 0.75rem;
}
.pr-4{
	padding-right: 1rem;
}
.pt-0\.5{
	padding-top: 0.125rem;
}
.pt-1{
	padding-top: 0.25rem;
}
.pt-10{
	padding-top: 2.5rem;
}
.pt-12{
	padding-top: 3rem;
}
.pt-2{
	padding-top: 0.5rem;
}
.pt-20{
	padding-top: 5rem;
}
.pt-3{
	padding-top: 0.75rem;
}
.pt-4{
	padding-top: 1rem;
}
.pt-5{
	padding-top: 1.25rem;
}
.pt-6{
	padding-top: 1.5rem;
}
.pt-\[max\(16px\2c env\(safe-area-inset-top\)\)\]{
	padding-top: max(16px, env(safe-area-inset-top));
}
.text-left{
	text-align: left;
}
.text-center{
	text-align: center;
}
.text-right{
	text-align: right;
}
.font-body{
	font-family: DM Sans, system-ui, sans-serif;
}
.font-display{
	font-family: Playfair Display, Georgia, serif;
}
.font-mono{
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}
.text-2xl{
	font-size: 1.5rem;
	line-height: 2rem;
}
.text-3xl{
	font-size: 1.875rem;
	line-height: 2.25rem;
}
.text-\[10px\]{
	font-size: 10px;
}
.text-\[11px\]{
	font-size: 11px;
}
.text-\[12px\]{
	font-size: 12px;
}
.text-\[13px\]{
	font-size: 13px;
}
.text-\[14px\]{
	font-size: 14px;
}
.text-\[15px\]{
	font-size: 15px;
}
.text-\[16px\]{
	font-size: 16px;
}
.text-\[17px\]{
	font-size: 17px;
}
.text-\[18px\]{
	font-size: 18px;
}
.text-\[20px\]{
	font-size: 20px;
}
.text-\[21px\]{
	font-size: 21px;
}
.text-\[22px\]{
	font-size: 22px;
}
.text-\[24px\]{
	font-size: 24px;
}
.text-\[26px\]{
	font-size: 26px;
}
.text-\[28px\]{
	font-size: 28px;
}
.text-\[30px\]{
	font-size: 30px;
}
.text-\[32px\]{
	font-size: 32px;
}
.text-\[34px\]{
	font-size: 34px;
}
.text-\[36px\]{
	font-size: 36px;
}
.text-\[40px\]{
	font-size: 40px;
}
.text-\[48px\]{
	font-size: 48px;
}
.text-lg{
	font-size: 1.125rem;
	line-height: 1.75rem;
}
.text-xl{
	font-size: 1.25rem;
	line-height: 1.75rem;
}
.font-bold{
	font-weight: 700;
}
.font-medium{
	font-weight: 500;
}
.font-normal{
	font-weight: 400;
}
.font-semibold{
	font-weight: 600;
}
.uppercase{
	text-transform: uppercase;
}
.capitalize{
	text-transform: capitalize;
}
.normal-case{
	text-transform: none;
}
.italic{
	font-style: italic;
}
.leading-5{
	line-height: 1.25rem;
}
.leading-7{
	line-height: 1.75rem;
}
.leading-\[1\.2\]{
	line-height: 1.2;
}
.leading-none{
	line-height: 1;
}
.leading-relaxed{
	line-height: 1.625;
}
.leading-snug{
	line-height: 1.375;
}
.leading-tight{
	line-height: 1.25;
}
.tracking-\[0\.12em\]{
	letter-spacing: 0.12em;
}
.tracking-\[0\.5px\]{
	letter-spacing: 0.5px;
}
.tracking-\[0\.6px\]{
	letter-spacing: 0.6px;
}
.tracking-\[0\.7px\]{
	letter-spacing: 0.7px;
}
.tracking-\[0\.8px\]{
	letter-spacing: 0.8px;
}
.tracking-\[1\.5px\]{
	letter-spacing: 1.5px;
}
.tracking-\[1\.6px\]{
	letter-spacing: 1.6px;
}
.tracking-\[1px\]{
	letter-spacing: 1px;
}
.tracking-\[2px\]{
	letter-spacing: 2px;
}
.tracking-\[3px\]{
	letter-spacing: 3px;
}
.tracking-normal{
	letter-spacing: 0em;
}
.tracking-wide{
	letter-spacing: 0.025em;
}
.tracking-widest{
	letter-spacing: 0.1em;
}
.text-\[\#1C1C1C\]{
	--tw-text-opacity: 1;
	color: rgb(28 28 28 / var(--tw-text-opacity, 1));
}
.text-\[var\(--on-gold\)\]{
	color: var(--on-gold);
}
.text-amber-600{
	--tw-text-opacity: 1;
	color: rgb(217 119 6 / var(--tw-text-opacity, 1));
}
.text-amber-700{
	--tw-text-opacity: 1;
	color: rgb(180 83 9 / var(--tw-text-opacity, 1));
}
.text-amber-800{
	--tw-text-opacity: 1;
	color: rgb(146 64 14 / var(--tw-text-opacity, 1));
}
.text-emerald-500{
	--tw-text-opacity: 1;
	color: rgb(16 185 129 / var(--tw-text-opacity, 1));
}
.text-emerald-600{
	--tw-text-opacity: 1;
	color: rgb(5 150 105 / var(--tw-text-opacity, 1));
}
.text-emerald-700{
	--tw-text-opacity: 1;
	color: rgb(4 120 87 / var(--tw-text-opacity, 1));
}
.text-gold{
	--tw-text-opacity: 1;
	color: rgb(var(--c-gold) / var(--tw-text-opacity, 1));
}
.text-gold-dark{
	--tw-text-opacity: 1;
	color: rgb(168 138 48 / var(--tw-text-opacity, 1));
}
.text-gold\/50{
	color: rgb(var(--c-gold) / 0.5);
}
.text-gray-500{
	--tw-text-opacity: 1;
	color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}
.text-ink{
	--tw-text-opacity: 1;
	color: rgb(var(--c-ink) / var(--tw-text-opacity, 1));
}
.text-ink-faint{
	--tw-text-opacity: 1;
	color: rgb(var(--c-ink-faint) / var(--tw-text-opacity, 1));
}
.text-ink-soft{
	--tw-text-opacity: 1;
	color: rgb(var(--c-ink-soft) / var(--tw-text-opacity, 1));
}
.text-red-300{
	--tw-text-opacity: 1;
	color: rgb(252 165 165 / var(--tw-text-opacity, 1));
}
.text-red-400{
	--tw-text-opacity: 1;
	color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}
.text-red-500{
	--tw-text-opacity: 1;
	color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}
.text-red-600{
	--tw-text-opacity: 1;
	color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}
.text-red-700{
	--tw-text-opacity: 1;
	color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}
.text-white{
	--tw-text-opacity: 1;
	color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.text-white\/30{
	color: rgb(255 255 255 / 0.3);
}
.text-white\/50{
	color: rgb(255 255 255 / 0.5);
}
.text-white\/60{
	color: rgb(255 255 255 / 0.6);
}
.text-white\/70{
	color: rgb(255 255 255 / 0.7);
}
.text-white\/80{
	color: rgb(255 255 255 / 0.8);
}
.text-white\/90{
	color: rgb(255 255 255 / 0.9);
}
.underline{
	text-decoration-line: underline;
}
.line-through{
	text-decoration-line: line-through;
}
.accent-gold{
	accent-color: rgb(var(--c-gold) / 1);
}
.opacity-0{
	opacity: 0;
}
.opacity-100{
	opacity: 1;
}
.opacity-20{
	opacity: 0.2;
}
.opacity-40{
	opacity: 0.4;
}
.opacity-50{
	opacity: 0.5;
}
.opacity-60{
	opacity: 0.6;
}
.opacity-70{
	opacity: 0.7;
}
.opacity-95{
	opacity: 0.95;
}
.shadow{
	--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
	--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-2xl{
	--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
	--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-card{
	--tw-shadow: 0 2px 12px rgba(26, 43, 74, 0.06);
	--tw-shadow-colored: 0 2px 12px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-card-lg{
	--tw-shadow: 0 8px 32px rgba(26, 43, 74, 0.12);
	--tw-shadow-colored: 0 8px 32px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-lg{
	--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
	--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-md{
	--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-sm{
	--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
	--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-xl{
	--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
	--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-\[var\(--shadow-card\)\]{
	--tw-shadow-color: var(--shadow-card);
	--tw-shadow: var(--tw-shadow-colored);
}
.shadow-card{
	--tw-shadow-color: rgb(var(--c-card) / 1);
	--tw-shadow: var(--tw-shadow-colored);
}
.outline-none{
	outline: 2px solid transparent;
	outline-offset: 2px;
}
.ring{
	--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
	--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
	box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.blur{
	--tw-blur: blur(8px);
	filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.drop-shadow{
	--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / 0.1)) drop-shadow(0 1px 1px rgb(0 0 0 / 0.06));
	filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.filter{
	filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.backdrop-blur{
	--tw-backdrop-blur: blur(8px);
	backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}
.backdrop-blur-md{
	--tw-backdrop-blur: blur(12px);
	backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}
.backdrop-blur-sm{
	--tw-backdrop-blur: blur(4px);
	backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}
.backdrop-filter{
	backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}
.transition{
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}
.transition-all{
	transition-property: all;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}
.transition-colors{
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}
.transition-opacity{
	transition-property: opacity;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}
.transition-transform{
	transition-property: transform;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}
.duration-150{
	transition-duration: 150ms;
}
.duration-200{
	transition-duration: 200ms;
}
.duration-300{
	transition-duration: 300ms;
}
.font-display {
    font-family: var(--font-serif);
  }
.font-body {
    font-family: var(--font-sans);
  }
.tap-hit {
    position: relative;
  }
.tap-hit::after {
    content: '';
    position: absolute;
    inset: -8px;
  }
.\[-ms-overflow-style\:none\]{
	-ms-overflow-style: none;
}
.\[scrollbar-width\:none\]{
	scrollbar-width: none;
}
.\[text-shadow\:none\]{
	text-shadow: none;
}
#root::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: var(--grain-opacity);
  mix-blend-mode: overlay;
}
#root::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: var(--star-opacity);
  background-image:
    radial-gradient(1px 1px at 14% 12%, rgba(255,255,255,.9), transparent),
    radial-gradient(1px 1px at 38% 7%, rgba(255,255,255,.6), transparent),
    radial-gradient(1.4px 1.4px at 62% 16%, rgba(231,200,119,.8), transparent),
    radial-gradient(1px 1px at 82% 9%, rgba(255,255,255,.7), transparent),
    radial-gradient(1px 1px at 26% 22%, rgba(255,255,255,.5), transparent),
    radial-gradient(1.3px 1.3px at 90% 24%, rgba(255,255,255,.6), transparent);
}
#root > * {
  position: relative;
  z-index: 1;
}
i.ti { line-height: 1; }
.auth-cinema {
  position:relative;
  overflow:hidden;
  background:#05070d;
  isolation:isolate;
  --scrim:.72;
}
.auth-cinema:has(.auth-form-reveal.is-revealed) { --scrim:1; }
.auth-cinema-video {
  position:absolute;
  inset:0;
  z-index:0;
  width:100%;
  height:100%;
  -o-object-fit:cover;
     object-fit:cover;
  -o-object-position:center;
     object-position:center;
  background:#05070d;
}
.auth-cinema-scrim {
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  opacity:var(--scrim);
  background:linear-gradient(180deg,
    rgba(7,9,16,0.66) 0%,
    rgba(7,9,16,0.32) 34%,
    rgba(7,9,16,0.40) 60%,
    rgba(7,9,16,0.80) 100%);
  transition:opacity 1s cubic-bezier(.2,.7,.2,1);
}
.auth-cinema-content {
  position:relative;
  z-index:2;
  padding-top:max(24px, env(safe-area-inset-top, 0px));
  padding-bottom:max(24px, env(safe-area-inset-bottom, 0px));
}
.auth-logo-reveal {
  position:relative;
  opacity:0;
  transform:scale(.97);
  filter:drop-shadow(0 0 0 rgba(201,168,76,0));
  transition:
    opacity 1s cubic-bezier(.2,.7,.2,1),
    transform 1s cubic-bezier(.2,.7,.2,1),
    filter 1.05s ease;
}
.auth-logo-reveal::before {
  content:"";
  position:absolute;
  inset:-34% -30% -26%;
  z-index:-1;
  pointer-events:none;
  background:radial-gradient(60% 55% at 50% 42%, rgba(7,9,16,0.55), rgba(7,9,16,0) 70%);
}
.auth-logo-reveal.is-revealed {
  opacity:1;
  transform:scale(1);
  filter:drop-shadow(0 0 24px rgba(201,168,76,.36));
}
.auth-logo-reveal.is-immediate {
  transition:none;
}
.auth-cinema-logo {
  max-height:min(31vh,190px);
  -o-object-fit:contain;
     object-fit:contain;
  filter:drop-shadow(0 2px 10px rgba(0,0,0,0.5));
}
.auth-form-reveal {
  opacity:0;
  visibility:hidden;
  transition:opacity .7s cubic-bezier(.2,.7,.2,1) .25s, visibility 0s linear .95s;
}
.auth-form-reveal.is-revealed {
  opacity:1;
  visibility:visible;
  transition:opacity .7s cubic-bezier(.2,.7,.2,1) .25s, visibility 0s;
}
.auth-form-reveal.is-immediate {
  transition:none;
}
.auth-form-reveal .text-gold,
.auth-form-reveal .text-gold svg {
  text-shadow:0 1px 8px rgba(0,0,0,0.55);
  filter:drop-shadow(0 1px 8px rgba(0,0,0,0.35));
}
.auth-form-reveal > .flex.border-b button {
  color:rgba(255,255,255,.72);
  text-shadow:0 1px 8px rgba(0,0,0,0.55);
}
.auth-form-reveal > .flex.border-b button.text-gold {
  color:var(--gold);
}
@media (prefers-reduced-motion: reduce) {
  .auth-logo-reveal,
  .auth-form-reveal {
    opacity:1;
    visibility:visible;
    transform:none;
    filter:none;
    transition:none;
  }
}
.app-header {
  flex: 0 0 auto;
  padding: 16px 18px 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: linear-gradient(180deg, var(--bg-grad-top) 60%, transparent);
}
.header-row { display:flex; align-items:center; justify-content:space-between; }
.brand { display:flex; align-items:center; gap:8px; min-width:0; }
.brand-logo { width:min(48vw, 174px); height:auto; display:block; }
.header-actions { display:flex; align-items:center; gap:14px; }
.theme-toggle { background:none; border:none; cursor:pointer; color:var(--ink-2); font-size:19px; display:grid; place-items:center; padding:0; }
.online { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--success); }
.online .dot { width:7px; height:7px; border-radius:50%; background:var(--success); }
.trip-switcher { align-self:center; display:inline-flex; align-items:center; gap:6px; font-size:14px; font-weight:500; color:var(--ink); border:0; background:transparent; padding:0; }
.trip-switcher i { color:var(--ink-3); font-size:16px; }
.app-content { flex:1 1 auto; overflow-y:auto; padding:4px 0 96px; }
.app-content::-webkit-scrollbar { width:0; }
.pad { padding-left:16px; padding-right:16px; }
.app-nav {
  position:fixed; left:0; right:0; bottom:0; z-index:800;
  display:flex; justify-content:space-around; align-items:center;
  padding:10px 8px calc(10px + env(safe-area-inset-bottom, 6px));
  background:linear-gradient(0deg, var(--bg-grad-bot) 70%, transparent);
  border-top:1px solid var(--divider);
  backdrop-filter:blur(8px);
}
.nav-item { display:flex; flex-direction:column; align-items:center; gap:3px; font-size:10px; letter-spacing:.3px; color:var(--ink-3); border:0; background:transparent; padding:0 8px; min-width:52px; }
.nav-item i { font-size:22px; }
.nav-item.active { color:var(--gold); }
.section-label { font-size:11px; letter-spacing:1.6px; text-transform:uppercase; color:var(--gold-text); margin:18px 2px 9px; font-weight:400; }
[data-theme="dark"] .section-label { color:var(--ink-2); }
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--shadow-card); }
.focal-card {
  position:relative;
  background:var(--flight-bg);
  border:1px solid var(--flight-edge);
  border-radius:var(--r-lg);
  padding:16px;
  box-shadow:var(--shadow-focal);
}
.focal-card .focal-head { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px; }
.focal-card .focal-title { font-family:var(--font-serif); font-weight:600; font-size:20px; color:var(--flight-fg); }
.focal-card .focal-sub { font-size:13px; color:var(--flight-fg); opacity:.85; }
.focal-card .focal-time { font-size:12.5px; color:var(--flight-fg); opacity:.9; }
.focal-card.stay { background:var(--stay-bg); border-color:var(--stay-edge); }
.focal-card.stay .focal-title,.focal-card.stay .focal-sub,.focal-card.stay .focal-time { color:var(--stay-fg); }
.focal-card.dining { background:var(--dining-bg); border-color:var(--dining-edge); }
.focal-card.dining .focal-title,.focal-card.dining .focal-sub,.focal-card.dining .focal-time { color:var(--dining-fg); }
.focal-card.transfer { background:var(--transfer-bg); border-color:var(--transfer-edge); }
.focal-card.transfer .focal-title,.focal-card.transfer .focal-sub,.focal-card.transfer .focal-time { color:var(--transfer-fg); }
.focal-card.activity { background:var(--activity-bg); border-color:var(--activity-edge); }
.focal-card.activity .focal-title,.focal-card.activity .focal-sub,.focal-card.activity .focal-time { color:var(--activity-fg); }
.list-group { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-card); }
.list-row { width:100%; display:flex; align-items:center; gap:12px; padding:13px 14px; border:0; border-bottom:1px solid var(--divider); background:transparent; text-align:left; }
.list-row:last-child { border-bottom:none; }
.row-icon { flex:0 0 auto; width:34px; height:34px; border-radius:var(--r-sm); display:grid; place-items:center; }
.row-icon i { font-size:17px; }
.row-icon.gold { background:var(--gold-tint); }
.row-icon.gold i { color:var(--gold-text); }
.row-icon.neutral { background:var(--surface-sunken); }
.row-icon.neutral i { color:var(--ink-2); }
.row-icon.danger { background:var(--danger-bg); }
.row-icon.danger i { color:var(--danger); }
.row-text { flex:1 1 auto; min-width:0; }
.row-title { font-size:14px; color:var(--ink); font-weight:400; }
.row-title.danger { color:var(--danger); }
.row-sub { font-size:12px; color:var(--ink-2); margin-top:1px; }
.chev { color:var(--ink-3); font-size:17px; flex:0 0 auto; }
.featured { width:100%; display:flex; align-items:center; gap:12px; background:var(--gold-tint); border:0; border-radius:var(--r-md); padding:13px 14px; text-align:left; }
.featured .f-icon { width:38px; height:38px; border-radius:var(--r-sm); background:var(--gold); display:grid; place-items:center; }
.featured .f-icon i { font-size:19px; color:var(--on-gold); }
.featured .f-title { font-size:14.5px; color:var(--gold-text); }
.featured .f-sub { font-size:12px; color:var(--gold-text); opacity:.8; }
.day-strip { display:flex; gap:8px; overflow-x:auto; padding:2px 0 4px; }
.day-strip::-webkit-scrollbar { height:0; }
.day-pill { flex:0 0 auto; width:58px; text-align:center; padding:9px 0; border-radius:var(--r-md); border:1px solid var(--border); background:var(--surface); }
.day-pill .dow { font-size:10px; letter-spacing:1px; color:var(--ink-3); }
.day-pill .dnum { font-family:var(--font-serif); font-size:19px; color:var(--ink); margin:2px 0; }
.day-pill .mon { font-size:10px; color:var(--ink-3); }
.day-pill .has { display:block; width:4px; height:4px; border-radius:50%; background:var(--gold); margin:4px auto 0; }
.day-pill.active { background:var(--ink); border-color:var(--ink); }
.day-pill.active .dow, .day-pill.active .mon { color:rgba(247,243,234,.7); }
.day-pill.active .dnum { color:var(--bg-grad-top); }
.event { border-left:3px solid var(--flight-edge); border-radius:0 var(--r-md) var(--r-md) 0; background:var(--surface); border-top:1px solid var(--border); border-right:1px solid var(--border); border-bottom:1px solid var(--border); padding:13px 14px; box-shadow:var(--shadow-card); }
.event.flight{border-left-color:var(--flight-edge)}
.event.stay{border-left-color:var(--stay-edge)}
.event.dining{border-left-color:var(--dining-edge)}
.event.transfer{border-left-color:var(--transfer-edge)}
.event.activity{border-left-color:var(--activity-edge)}
.event .e-top { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:6px; }
.event .e-time { font-size:12.5px; color:var(--ink-2); }
.event .e-title { font-family:var(--font-serif); font-size:17px; color:var(--ink); }
.event .e-sub { font-size:12.5px; color:var(--ink-2); margin-top:2px; }
.day-head { display:flex; align-items:center; gap:8px; margin:18px 0 10px; }
.day-head .bar { width:3px; height:16px; background:var(--gold); border-radius:2px; }
.day-head .d { font-size:14px; font-weight:500; color:var(--ink); }
.badge { display:inline-flex; align-items:center; gap:5px; font-size:11px; letter-spacing:.4px; font-weight:500; padding:4px 10px; border-radius:var(--r-pill); text-transform:uppercase; }
.badge i { font-size:13px; }
.badge.flight{background:color-mix(in srgb, var(--flight-dot) 18%, transparent); color:var(--flight-fg);}
.badge.stay{background:color-mix(in srgb, var(--stay-dot) 18%, transparent); color:var(--stay-fg);}
.badge.dining{background:color-mix(in srgb, var(--dining-dot) 18%, transparent); color:var(--dining-fg);}
.badge.transfer{background:color-mix(in srgb, var(--transfer-dot) 18%, transparent); color:var(--transfer-fg);}
.badge.activity{background:color-mix(in srgb, var(--activity-dot) 18%, transparent); color:var(--activity-fg);}
.sheet { position:fixed; left:0; right:0; bottom:0; z-index:1210; background:var(--surface); border-radius:var(--r-xl) var(--r-xl) 0 0; border-top:1px solid var(--border); box-shadow:0 -20px 50px rgba(0,0,0,.25); padding:10px 18px 26px; max-height:85vh; overflow-y:auto; }
.sheet .grip { width:38px; height:4px; border-radius:2px; background:var(--border-strong); margin:2px auto 16px; }
.sheet h2 { font-family:var(--font-serif); font-weight:600; font-size:24px; margin:10px 0 4px; color:var(--ink); }
.sheet .when { font-size:13px; color:var(--ink-2); margin-bottom:16px; }
.sheet-actions { display:flex; gap:10px; margin-bottom:18px; }
.sheet-actions .a { flex:1; display:flex; flex-direction:column; align-items:center; gap:6px; padding:13px; border:1px solid var(--border); border-radius:var(--r-md); font-size:12px; color:var(--ink); background:var(--surface-2); }
.sheet-actions .a i { font-size:20px; color:var(--gold); }
.detail-row { padding:11px 0; border-top:1px solid var(--divider); }
.detail-row .k { font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--ink-3); margin-bottom:3px; }
.detail-row .v { font-size:14px; color:var(--ink); }
.detail-row .v.mono { font-family:ui-monospace, 'SF Mono', monospace; }
.fab { position:fixed; right:16px; bottom:84px; display:inline-flex; align-items:center; gap:8px; background:var(--gold); color:var(--on-gold); padding:12px 18px; border-radius:var(--r-pill); font-size:14px; box-shadow:0 10px 26px rgba(184,146,60,.4); border:0; }
.fab i { font-size:18px; }
.fab.round { padding:0; width:52px; height:52px; justify-content:center; }
.segmented { display:flex; gap:8px; }
.seg { flex:1; display:flex; align-items:center; justify-content:center; gap:6px; font-size:13px; padding:8px; border-radius:var(--r-pill); border:1px solid var(--border); background:var(--surface); color:var(--ink-2); }
.seg.active { background:var(--ink); color:var(--bg-grad-top); border-color:var(--ink); }
.seg i { font-size:15px; }
.searchbar { display:flex; align-items:center; gap:9px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-pill); padding:10px 14px; }
.searchbar i { color:var(--ink-2); font-size:16px; }
.searchbar .ph { flex:1; font-size:13.5px; color:var(--ink-3); }
.chips { display:flex; gap:8px; overflow-x:auto; padding-bottom:2px; }
.chips::-webkit-scrollbar { height:0; }
.chip { display:inline-flex; align-items:center; gap:5px; white-space:nowrap; font-size:12px; padding:6px 12px; border-radius:var(--r-pill); border:1px solid var(--border); background:var(--surface); color:var(--ink); }
.chip i { font-size:14px; }
.chip.active { background:var(--gold); color:var(--on-gold); border-color:var(--gold); }
.map-canvas { position:relative; margin:0 14px; height:360px; border-radius:var(--r-lg); overflow:hidden; background:var(--surface-sunken); border:1px solid var(--border); }
[data-theme="dark"] .map-canvas { background:#0E1626; }
.map-pin { width:26px; height:26px; border-radius:50%; border:2px solid var(--bg-grad-top); display:grid; place-items:center; box-shadow:0 4px 10px rgba(0,0,0,.25); }
.map-pin i { font-size:13px; color:#fff; }
.map-pin.flight{background:var(--flight-dot)}
.map-pin.stay{background:var(--stay-dot)}
.map-pin.dining{background:var(--dining-dot)}
.map-pin.transfer{background:var(--transfer-dot)}
.map-pin.activity{background:var(--activity-dot)}
.map-fab-tr { display:inline-flex; align-items:center; gap:6px; background:var(--surface); border:1px solid var(--border-strong); border-radius:var(--r-pill); padding:6px 12px; font-size:12px; color:var(--ink); box-shadow:var(--shadow-card); }
.map-fab-tr i { color:var(--gold); font-size:14px; }
.map-controls { display:flex; flex-direction:column; gap:8px; }
.map-controls .ctl { width:36px; height:36px; border-radius:var(--r-sm); background:var(--surface); border:1px solid var(--border-strong); display:grid; place-items:center; box-shadow:var(--shadow-card); }
.map-controls .ctl i { font-size:17px; color:var(--ink); }
.place-card { display:flex; align-items:center; gap:11px; }
.place-thumb { width:34px; height:34px; border-radius:50%; display:grid; place-items:center; }
.place-thumb.dining { background:var(--dining-bg); }
.place-thumb.dining i { color:var(--dining-fg); }
.post { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-card); }
.post-head { display:flex; align-items:center; gap:10px; padding:12px 14px; }
.avatar { width:34px; height:34px; border-radius:50%; display:grid; place-items:center; font-size:12px; font-weight:500; background:var(--gold-tint); color:var(--gold-text); }
.post-author { font-size:13.5px; color:var(--ink); }
.post-meta { font-size:11.5px; color:var(--ink-3); }
.post-photo { width:100%; height:230px; -o-object-fit:cover; object-fit:cover; display:block; }
.post-body { padding:12px 14px; }
.post-caption { font-size:14px; color:var(--ink); }
.reactions { display:flex; gap:8px; margin-top:12px; }
.react { display:inline-flex; align-items:center; gap:5px; font-size:12px; color:var(--ink-2); border:1px solid var(--border); border-radius:var(--r-pill); padding:4px 10px; background:transparent; }
.react i { font-size:14px; color:var(--gold); }
.chat-status { display:flex; align-items:center; gap:7px; font-size:12px; color:var(--success); padding:4px 2px 12px; }
.chat-day { text-align:center; font-size:11px; color:var(--ink-3); margin:6px 0 14px; }
.msg-row { display:flex; gap:8px; margin-bottom:12px; align-items:flex-end; }
.msg-row.me { flex-direction:row-reverse; }
.bubble { max-width:74%; padding:9px 13px; font-size:14px; line-height:1.4; border-radius:16px; }
.bubble.them { background:var(--surface); border:1px solid var(--border); color:var(--ink); border-bottom-left-radius:5px; }
.bubble.me { background:var(--gold); color:var(--on-gold); border-bottom-right-radius:5px; }
.msg-time { font-size:10.5px; color:var(--ink-3); margin-top:4px; display:block; }
.msg-row.me .msg-time { text-align:right; }
.chat-input { display:flex; align-items:center; gap:10px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-pill); padding:9px 12px; margin:6px 0 4px; }
.chat-input i { color:var(--ink-2); font-size:18px; }
.chat-input .ph { flex:1; font-size:13.5px; color:var(--ink-3); }
.chat-input .send { width:32px; height:32px; border-radius:50%; background:var(--gold); display:grid; place-items:center; }
.chat-input .send i { color:var(--on-gold); font-size:16px; }
.concierge-page { position:fixed; inset:0; z-index:900; display:flex; flex-direction:column; background:linear-gradient(180deg,var(--bg-grad-top),var(--bg-grad-bot)); padding-bottom:env(safe-area-inset-bottom, 0px); }
.concierge-head { display:flex; align-items:center; justify-content:space-between; padding:16px 16px 10px; }
.concierge-title { display:flex; align-items:center; gap:9px; }
.concierge-title .back { font-size:20px; color:var(--ink-2); }
.concierge-title .t { font-family:var(--font-serif); font-weight:600; font-size:19px; color:var(--ink); }
.concierge-new { display:flex; align-items:center; gap:6px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-pill); padding:7px 13px; color:var(--ink-2); font-size:12px; font-weight:500; }
.concierge-greet { display:flex; align-items:center; gap:13px; padding:6px 18px 14px; }
.navi { position:relative; width:48px; height:48px; border-radius:50%; flex:0 0 auto; display:grid; place-items:center; background:radial-gradient(circle at 50% 35%,#243049,#0c1220); box-shadow:0 0 0 1px rgba(216,180,92,.5),0 8px 22px rgba(184,146,60,.35); }
[data-theme="dark"] .navi { box-shadow:0 0 22px rgba(216,180,92,.5),0 0 0 1px rgba(216,180,92,.55); }
.navi img { width:32px; height:32px; display:block; }
.navi.mini { width:28px; height:28px; }
.navi.mini img { width:18px; height:18px; }
.concierge-g1 { font-family:var(--font-serif); font-size:18px; color:var(--ink); line-height:1.2; }
.concierge-g2 { font-size:12px; color:var(--ink-2); margin-top:3px; display:flex; align-items:center; gap:5px; }
.concierge-g2 i { font-size:13px; color:var(--gold); }
.concierge-suggestions { display:flex; gap:8px; overflow-x:auto; padding:0 16px 12px; }
.concierge-suggestions::-webkit-scrollbar { height:0; }
.schip { white-space:nowrap; font-size:12.5px; padding:8px 13px; border-radius:var(--r-pill); border:1px solid var(--gold-tint); background:var(--gold-tint); color:var(--gold-text); }
.schip i { font-size:13px; margin-right:4px; }
.concierge-thread { flex:1; overflow-y:auto; padding:6px 16px 8px; display:flex; flex-direction:column; gap:12px; }
.concierge-thread::-webkit-scrollbar { width:0; }
.concierge-row { display:flex; gap:9px; align-items:flex-end; }
.concierge-row.me { flex-direction:row-reverse; }
.concierge-bubble { max-width:80%; padding:11px 14px; font-size:16px; line-height:1.5; border-radius:16px; }
.concierge-bubble.them { background:var(--surface); border:1px solid var(--border); color:var(--ink); border-bottom-left-radius:5px; }
.concierge-bubble.me { background:var(--gold); color:var(--on-gold); border-bottom-right-radius:5px; }
.concierge-rich { max-width:92%; width:100%; background:var(--surface); border:1px solid var(--border); border-radius:15px; box-shadow:var(--shadow-card); padding:12px; }
.concierge-inputbar { display:flex; align-items:center; gap:10px; margin:6px 14px calc(14px + env(safe-area-inset-bottom,4px)); background:var(--surface); border:1px solid var(--border); border-radius:var(--r-pill); padding:9px 12px; box-shadow:0 10px 30px rgba(0,0,0,.12); }
.concierge-inputbar input { flex:1; min-width:0; border:0; outline:0; background:transparent; font:400 16px var(--font-sans); color:var(--ink); }
.concierge-inputbar i { color:var(--ink-2); font-size:18px; }
.concierge-inputbar .send { width:34px; height:34px; border-radius:50%; background:var(--gold); display:grid; place-items:center; border:0; flex:0 0 auto; }
.concierge-inputbar .send i { color:var(--on-gold); font-size:16px; }
.today-hero {
  position:relative;
  height:420px;
  margin:4px 0 0;
  overflow:hidden;
  border-radius:var(--r-xl);
  background:#0b0e15;
  border:1px solid var(--border);
  isolation:isolate;
}
.today-hero-photo {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  -o-object-fit:cover;
     object-fit:cover;
  z-index:0;
  filter:contrast(1.08) saturate(1.12) brightness(1);
  transform:scale(1.02);
  transition:filter 900ms ease, opacity 900ms ease;
}
[data-theme="dark"] .today-hero-photo {
  filter:contrast(1.05) saturate(.95) brightness(.62);
}
.today-hero-grade {
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:rgba(214,168,66,.22);
  mix-blend-mode:multiply;
  transition:background 900ms ease, opacity 900ms ease;
}
[data-theme="dark"] .today-hero-grade {
  background:rgba(5,10,28,.5);
}
.today-hero-sky,
.today-hero-estela {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
}
.today-hero-sky { z-index:2; opacity:.58; mix-blend-mode:screen; pointer-events:none; }
.today-hero.no-photo .today-hero-sky { opacity:1; mix-blend-mode:normal; }
.today-hero-estela { z-index:5; opacity:.94; mix-blend-mode:screen; pointer-events:none; }
.today-hero-grain {
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  mix-blend-mode:overlay;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.today-hero-scrim {
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
  background:linear-gradient(180deg, transparent 0%, transparent 40%, rgba(8,10,16,.56) 76%, var(--bg-grad-bot) 100%);
}
.today-hero-body {
  position:absolute;
  inset:0;
  z-index:6;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:18px;
  color:#F7F3EA;
  text-shadow:0 2px 20px rgba(0,0,0,.52);
}
.today-hero-eyebrow {
  font-size:11px;
  letter-spacing:2.4px;
  color:#F4DCA0;
  margin-bottom:7px;
  text-transform:uppercase;
}
.today-hero-title {
  font-family:var(--font-serif);
  font-weight:600;
  font-size:38px;
  line-height:1.04;
  color:#F7F3EA;
}
.today-hero-sub {
  font-size:13px;
  color:rgba(247,243,234,.88);
  margin-top:8px;
}
.today-count {
  display:inline-flex;
  align-items:center;
  gap:9px;
  margin-top:16px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(8,10,16,.78);
  backdrop-filter:blur(10px) saturate(1.15);
  box-shadow:0 12px 34px rgba(20,18,10,.16), inset 0 1px 0 rgba(255,255,255,.18);
  padding:9px 15px;
  border-radius:var(--r-pill);
  font-size:13px;
  color:#080A10;
  align-self:flex-start;
}
[data-theme="dark"] .today-count {
  background:rgba(10,12,20,.42);
  border-color:rgba(244,220,160,.4);
  color:#F7F3EA;
  box-shadow:none;
}
[data-theme="dark"] .today-count i { color:#F4DCA0; }
.today-count i { color:#080A10; font-size:16px; }
.today-count b { font-weight:500; }
.today-hero-note {
  display:flex;
  align-items:center;
  gap:8px;
  margin:12px 2px 12px;
  font-size:12px;
  color:var(--ink-2);
}
.today-hero-note i { color:var(--gold); font-size:15px; }
.today-hero-rise { opacity:0; transform:translateY(16px); animation:todayRise .9s cubic-bezier(.2,.7,.2,1) forwards; }
.today-hero-rise.d1 { animation-delay:.15s; }
.today-hero-rise.d2 { animation-delay:.32s; }
.today-hero-rise.d3 { animation-delay:.5s; }
@keyframes todayRise { to { opacity:1; transform:translateY(0); } }
@media (prefers-reduced-motion: reduce) {
  .today-hero-rise { opacity:1; transform:none; animation:none; }
}
/* Shimmer animation for loading card */
@keyframes shimmer {
  0% { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}
.shimmer {
  background: linear-gradient(
    90deg,
    rgba(201, 168, 76, 0) 0%,
    rgba(201, 168, 76, 0.15) 50%,
    rgba(201, 168, 76, 0) 100%
  );
  background-size: 800px 100%;
  animation: shimmer 2s infinite linear;
}
/* Image block shimmer (light + dark) */
@keyframes imgShimmer {
  0%   { background-position: -600px 0; }
  100% { background-position: 600px 0; }
}
.img-shimmer {
  background: linear-gradient(90deg, #f0ece3 25%, #f7f3ea 50%, #f0ece3 75%);
  background-size: 1200px 100%;
  animation: imgShimmer 1.5s infinite linear;
}
.dark .img-shimmer {
  background: linear-gradient(90deg, rgb(26 35 50) 25%, rgb(35 48 68) 50%, rgb(26 35 50) 75%);
  background-size: 1200px 100%;
  animation: imgShimmer 1.5s infinite linear;
}
/* Entrance animations */
@keyframes fadeSlideUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes fadeScale {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes planePulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}
.animate-fade-slide-up {
  animation: fadeSlideUp 0.3s ease forwards;
}
.animate-fade-slide-up-delay-1 {
  opacity: 0;
  animation: fadeSlideUp 0.4s ease 0.1s forwards;
}
.animate-fade-slide-up-delay-2 {
  opacity: 0;
  animation: fadeSlideUp 0.5s ease 0.2s forwards;
}
.animate-fade-scale-delay-3 {
  opacity: 0;
  animation: fadeScale 0.5s ease 0.3s forwards;
}
.animate-fade-in-delay-3 {
  opacity: 0;
  animation: fadeIn 0.5s ease 0.3s forwards;
}
@keyframes fadeSlideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.animate-fade-slide-down {
  animation: fadeSlideDown 0.25s ease forwards;
}
.animate-plane-pulse {
  display: inline-block;
  animation: planePulse 2s ease-in-out infinite;
}
.placeholder\:text-ink-faint::-moz-placeholder{
	--tw-text-opacity: 1;
	color: rgb(var(--c-ink-faint) / var(--tw-text-opacity, 1));
}
.placeholder\:text-ink-faint::placeholder{
	--tw-text-opacity: 1;
	color: rgb(var(--c-ink-faint) / var(--tw-text-opacity, 1));
}
.placeholder\:text-white\/40::-moz-placeholder{
	color: rgb(255 255 255 / 0.4);
}
.placeholder\:text-white\/40::placeholder{
	color: rgb(255 255 255 / 0.4);
}
.before\:absolute::before{
	content: var(--tw-content);
	position: absolute;
}
.before\:-left-0::before{
	content: var(--tw-content);
	left: -0px;
}
.before\:content-\[\'\2022\'\]::before{
	--tw-content: '•';
	content: var(--tw-content);
}
.last\:border-0:last-child{
	border-width: 0px;
}
.last\:border-b-0:last-child{
	border-bottom-width: 0px;
}
.last\:pb-0:last-child{
	padding-bottom: 0px;
}
.hover\:border-gold\/40:hover{
	border-color: rgb(var(--c-gold) / 0.4);
}
.hover\:bg-gold-dark:hover{
	--tw-bg-opacity: 1;
	background-color: rgb(168 138 48 / var(--tw-bg-opacity, 1));
}
.hover\:bg-gold\/10:hover{
	background-color: rgb(var(--c-gold) / 0.1);
}
.hover\:bg-gold\/15:hover{
	background-color: rgb(var(--c-gold) / 0.15);
}
.hover\:bg-ink\/5:hover{
	background-color: rgb(var(--c-ink) / 0.05);
}
.hover\:bg-red-500\/10:hover{
	background-color: rgb(239 68 68 / 0.1);
}
.hover\:text-gold:hover{
	--tw-text-opacity: 1;
	color: rgb(var(--c-gold) / var(--tw-text-opacity, 1));
}
.hover\:text-ink:hover{
	--tw-text-opacity: 1;
	color: rgb(var(--c-ink) / var(--tw-text-opacity, 1));
}
.hover\:text-red-400:hover{
	--tw-text-opacity: 1;
	color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}
.hover\:text-red-600:hover{
	--tw-text-opacity: 1;
	color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}
.hover\:text-white\/80:hover{
	color: rgb(255 255 255 / 0.8);
}
.focus\:border-gold:focus{
	--tw-border-opacity: 1;
	border-color: rgb(var(--c-gold) / var(--tw-border-opacity, 1));
}
.focus\:border-gold\/50:focus{
	border-color: rgb(var(--c-gold) / 0.5);
}
.focus\:border-red-400:focus{
	--tw-border-opacity: 1;
	border-color: rgb(248 113 113 / var(--tw-border-opacity, 1));
}
.focus\:outline-none:focus{
	outline: 2px solid transparent;
	outline-offset: 2px;
}
.focus\:ring-2:focus{
	--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
	--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
	box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.focus\:ring-gold\/20:focus{
	--tw-ring-color: rgb(var(--c-gold) / 0.2);
}
.focus-visible\:ring-2:focus-visible{
	--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
	--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
	box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.focus-visible\:ring-gold\/50:focus-visible{
	--tw-ring-color: rgb(var(--c-gold) / 0.5);
}
.active\:scale-90:active{
	--tw-scale-x: .9;
	--tw-scale-y: .9;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.active\:scale-95:active{
	--tw-scale-x: .95;
	--tw-scale-y: .95;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.active\:scale-\[0\.97\]:active{
	--tw-scale-x: 0.97;
	--tw-scale-y: 0.97;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.active\:scale-\[0\.98\]:active{
	--tw-scale-x: 0.98;
	--tw-scale-y: 0.98;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.active\:scale-\[0\.99\]:active{
	--tw-scale-x: 0.99;
	--tw-scale-y: 0.99;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.active\:bg-gold-dark:active{
	--tw-bg-opacity: 1;
	background-color: rgb(168 138 48 / var(--tw-bg-opacity, 1));
}
.active\:bg-gold-light\/30:active{
	background-color: rgb(245 237 214 / 0.3);
}
.active\:bg-gold\/15:active{
	background-color: rgb(var(--c-gold) / 0.15);
}
.active\:bg-gold\/90:active{
	background-color: rgb(var(--c-gold) / 0.9);
}
.active\:bg-ink\/5:active{
	background-color: rgb(var(--c-ink) / 0.05);
}
.active\:text-red-400:active{
	--tw-text-opacity: 1;
	color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}
.active\:opacity-100:active{
	opacity: 1;
}
.active\:opacity-60:active{
	opacity: 0.6;
}
.active\:opacity-70:active{
	opacity: 0.7;
}
.disabled\:opacity-20:disabled{
	opacity: 0.2;
}
.disabled\:opacity-30:disabled{
	opacity: 0.3;
}
.disabled\:opacity-35:disabled{
	opacity: 0.35;
}
.disabled\:opacity-40:disabled{
	opacity: 0.4;
}
.disabled\:opacity-50:disabled{
	opacity: 0.5;
}
.disabled\:opacity-60:disabled{
	opacity: 0.6;
}
.disabled\:opacity-90:disabled{
	opacity: 0.9;
}
.group:focus-within .group-focus-within\:opacity-100{
	opacity: 1;
}
.group:hover .group-hover\:opacity-100{
	opacity: 1;
}
@media (min-width: 380px){
	.min-\[380px\]\:inline{
		display: inline;
	}
}
@media (min-width: 640px){
	.sm\:left-1\/2{
		left: 50%;
	}
	.sm\:right-auto{
		right: auto;
	}
	.sm\:w-\[420px\]{
		width: 420px;
	}
	.sm\:-translate-x-1\/2{
		--tw-translate-x: -50%;
		transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
	}
	.sm\:grid-cols-2{
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.sm\:px-0{
		padding-left: 0px;
		padding-right: 0px;
	}
	.sm\:px-8{
		padding-left: 2rem;
		padding-right: 2rem;
	}
	.sm\:py-8{
		padding-top: 2rem;
		padding-bottom: 2rem;
	}
}
.\[\&\:\:-webkit-scrollbar\]\:hidden::-webkit-scrollbar{
	display: none;
}
