/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-600:oklch(57.7% .245 27.325);--color-orange-600:oklch(64.6% .222 41.116);--color-orange-700:oklch(55.3% .195 38.402);--color-yellow-50:oklch(98.7% .026 102.212);--color-yellow-400:oklch(85.2% .199 91.936);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-blue-900:oklch(37.9% .146 265.522);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--container-3xl:48rem;--container-4xl:56rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-normal:400;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.right-0{right:calc(var(--spacing) * 0)}.right-2{right:calc(var(--spacing) * 2)}.bottom-0{bottom:calc(var(--spacing) * 0)}.left-0{left:calc(var(--spacing) * 0)}.z-10{z-index:10}.z-20{z-index:20}.col-span-4{grid-column:span 4/span 4}.col-span-full{grid-column:1/-1}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.my-4{margin-block:calc(var(--spacing) * 4)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.ml-1{margin-left:calc(var(--spacing) * 1)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.table{display:table}.h-4{height:calc(var(--spacing) * 4)}.max-h-\[40vh\]{max-height:40vh}.min-h-screen{min-height:100vh}.w-4{width:calc(var(--spacing) * 4)}.w-6{width:calc(var(--spacing) * 6)}.w-12{width:calc(var(--spacing) * 12)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-full{width:100%}.max-w-3xl{max-width:var(--container-3xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.flex-1{flex:1}.shrink{flex-shrink:1}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.cursor-pointer{cursor:pointer}.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))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-1>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * 1) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-x-reverse)))}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-t-2{border-top-style:var(--tw-border-style);border-top-width:2px}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-green-600{background-color:var(--color-green-600)}.bg-red-600{background-color:var(--color-red-600)}.bg-white{background-color:var(--color-white)}.bg-yellow-50{background-color:var(--color-yellow-50)}.bg-yellow-400{background-color:var(--color-yellow-400)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pr-10{padding-right:calc(var(--spacing) * 10)}.pb-8{padding-bottom:calc(var(--spacing) * 8)}.pb-12{padding-bottom:calc(var(--spacing) * 12)}.pb-32{padding-bottom:calc(var(--spacing) * 32)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-extrabold{--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-black{color:var(--color-black)}.text-blue-900{color:var(--color-blue-900)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-green-700{color:var(--color-green-700)}.text-orange-600{color:var(--color-orange-600)}.text-orange-700{color:var(--color-orange-700)}.text-red-600{color:var(--color-red-600)}.text-white{color:var(--color-white)}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.line-through{text-decoration-line:line-through}.underline{text-decoration-line:underline}.opacity-50{opacity:.5}.opacity-80{opacity:.8}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-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,)}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.hover\:scale-110:hover{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:40rem){.sm\:col-span-2{grid-column:span 2/span 2}.sm\:col-span-4{grid-column:span 4/span 4}.sm\:col-span-5{grid-column:span 5/span 5}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.sm\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}}:root{--ffss-bleu:#002654;--ffss-bleu-clair:#1a3d72;--ffss-jaune:#f4c20d;--ffss-jaune-fonce:#c79900;--ffss-bg:#f5f7fb;--rouge:#dc2626;--vert:#16a34a}html,body{background:var(--ffss-bg);height:100dvh;margin:0;overflow:hidden}body{flex-direction:column;display:flex}button{-webkit-tap-highlight-color:transparent}button:active{transform:scale(.97)}.btn-ffss-primary{background:var(--ffss-bleu);color:#fff}.btn-ffss-primary:hover{background:var(--ffss-bleu-clair)}.btn-ffss-jaune{background:var(--ffss-jaune);color:var(--ffss-bleu)}.btn-ffss-jaune:hover{background:var(--ffss-jaune-fonce)}.cat-tab{cursor:pointer;border-radius:.5rem .5rem 0 0;padding:.75rem 1rem;font-weight:600}.cat-tab.active{background:var(--ffss-bleu);color:#fff}.cat-tab:not(.active){color:var(--ffss-bleu);background:#fff}#articles-grid{grid-template-columns:repeat(auto-fill,minmax(130px,160px));justify-content:start;gap:.5rem;padding:.75rem .5rem .5rem}.article-btn{text-align:center;color:var(--ffss-bleu);aspect-ratio:1;cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.15rem;min-height:0;padding:.4rem .25rem;font-size:.78rem;font-weight:600;transition:transform 80ms ease-out,box-shadow .15s,border-color .15s;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 6px #00265414,0 1px 2px #0000000a}.article-btn:hover{border-color:var(--ffss-bleu);transform:translateY(-2px);box-shadow:0 6px 16px #00265426,0 2px 4px #0000000f}.article-btn:active{transform:translateY(0)scale(.97)}.article-btn .emoji{font-size:1.5rem;line-height:1}.article-btn .nom{-webkit-line-clamp:2;word-break:break-word;-webkit-hyphens:auto;hyphens:auto;-webkit-box-orient:vertical;font-size:.78rem;line-height:1.1;display:-webkit-box;overflow:hidden}.article-btn .prix{background:linear-gradient(135deg, var(--ffss-jaune) 0%, var(--ffss-jaune-fonce) 100%);color:var(--ffss-bleu);border-radius:999px;margin-top:.1rem;padding:.05rem .35rem;font-size:.78rem;font-weight:700;line-height:1.2;box-shadow:0 1px 2px #0000001a}@media (min-width:768px){#articles-grid{grid-template-columns:repeat(auto-fill,minmax(140px,160px));gap:.6rem;padding:.75rem .6rem .6rem}.article-btn{padding:.5rem .3rem}.article-btn .emoji{font-size:1.75rem}.article-btn .nom{font-size:.85rem}.article-btn .prix{padding:.1rem .45rem;font-size:.82rem}}.article-btn[data-cat=restauration]{border-top:4px solid #ea580c}.article-btn[data-cat=soft]{border-top:4px solid #0284c7}.article-btn[data-cat=alcool]{border-top:4px solid #9333ea}.article-btn[data-cat=consigne]{border-top:4px solid #15803d}.article-btn[data-cat=autre]{border-top:4px solid #64748b}.section-titre{color:var(--ffss-bleu);border-bottom:2px solid #e2e8f0;grid-column:1/-1;align-items:center;gap:.5rem;margin:1.2rem 0 .5rem;padding-bottom:.4rem;font-size:1rem;font-weight:700;display:flex}.section-titre:first-child{margin-top:.2rem}.section-titre .pill{color:#fff;border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:600}.section-titre[data-cat=restauration] .pill{background:#ea580c}.section-titre[data-cat=soft] .pill{background:#0284c7}.section-titre[data-cat=alcool] .pill{background:#9333ea}.section-titre[data-cat=consigne] .pill{background:#15803d}.section-titre[data-cat=autre] .pill{background:#64748b}.pay-card{cursor:pointer;color:#475569;background:#fff;border:2px solid #e2e8f0;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:.2rem;min-height:64px;padding:.6rem .4rem;font-weight:700;transition:transform 80ms ease-out,box-shadow .15s,border-color .15s,background .15s;display:flex;box-shadow:0 1px 3px #0000000d}.pay-card:hover{transform:translateY(-1px);box-shadow:0 3px 8px #0000001a}.pay-card:active{transform:translateY(0)scale(.97)}.pay-card .emoji{font-size:1.4rem;line-height:1}.pay-card .lbl{font-size:.85rem}.pay-card.active{background:linear-gradient(135deg, var(--ffss-bleu) 0%, var(--ffss-bleu-clair) 100%);color:#fff;border-color:var(--ffss-bleu);box-shadow:0 4px 12px #0026544d}.ticket-line{border-bottom:1px solid #e5e7eb;grid-template-columns:1fr auto auto;align-items:center;gap:.5rem;padding:.5rem;display:grid}.qty-btn{background:var(--ffss-bleu);color:#fff;border-radius:50%;width:36px;height:36px;font-weight:700}.qty-btn.minus{background:#6b7280}.qty-btn.del{background:var(--rouge)}.toast{background:var(--vert);color:#fff;z-index:50;text-align:center;border-radius:.5rem;max-width:90%;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;position:fixed;bottom:1rem;left:50%;transform:translate(-50%);box-shadow:0 10px 25px #0003}.toast.error{background:var(--rouge)}.toast.info{background:var(--ffss-bleu)}.toast.warn{background:var(--ffss-jaune);color:var(--ffss-bleu)}.banner-warn{background:var(--rouge);color:#fff;text-align:center;padding:.5rem;font-weight:700}.banner-info{background:var(--ffss-jaune);color:var(--ffss-bleu);text-align:center;padding:.4rem;font-weight:600}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:1rem;height:1rem;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.queue-badge{background:var(--ffss-jaune);color:var(--ffss-bleu);border-radius:1rem;padding:.25rem .75rem;font-size:.85rem;font-weight:700;display:inline-block}.strength-bar{background:#e5e7eb;border-radius:.25rem;height:.5rem;overflow:hidden}.strength-bar-fill{height:100%;transition:width .2s,background .2s}.strength-level-0,.strength-level-1{background:var(--rouge)}.strength-level-2{background:#f59e0b}.strength-level-3{background:#84cc16}.strength-level-4{background:var(--vert)}@media (max-width:640px){.article-btn{min-height:0;font-size:.78rem}}#caisses-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.caisse-card{background:var(--ffss-bleu);color:#fff;text-align:center;cursor:pointer;border:3px solid #0000;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;min-height:140px;padding:2rem 1rem;font-weight:700;transition:transform 80ms ease-out,box-shadow .15s,background .15s;display:flex;box-shadow:0 3px 10px #00265433}.caisse-card:hover{background:var(--ffss-bleu-clair);transform:translateY(-2px);box-shadow:0 6px 18px #0026544d}.caisse-card:active{transform:translateY(0)scale(.97)}.caisse-card.current{border-color:var(--ffss-jaune);box-shadow:0 0 0 3px var(--ffss-jaune-fonce), 0 6px 18px #0026544d}.caisse-card .caisse-num{font-size:3rem;font-weight:800;line-height:1}.caisse-card .caisse-lbl{opacity:.95;text-align:center;padding:0 .25rem;font-size:.95rem;font-weight:700}.caisse-card .caisse-printer{opacity:.8;margin-top:.25rem;font-size:.75rem}.caisse-card .caisse-printer-none{opacity:.85;margin-top:.25rem;font-size:.7rem;font-style:italic}.caisse-card.volante{background:linear-gradient(135deg,#ea580c 0%,#c2410c 100%);box-shadow:0 3px 10px #ea580c40}.caisse-card.volante:hover{background:linear-gradient(135deg,#c2410c 0%,#9a3412 100%);box-shadow:0 6px 18px #ea580c59}.caisse-pill{background:var(--ffss-jaune);color:var(--ffss-bleu);cursor:pointer;border:none;border-radius:999px;align-items:center;gap:.3rem;min-height:32px;padding:.35rem .8rem;font-size:.85rem;font-weight:700;text-decoration:none;display:inline-flex}.caisse-pill.unset{color:#fff;background:#6b7280}.caisse-pill:hover{filter:brightness(1.08)}.reprint-modal-backdrop{z-index:100;background:#0000008c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.reprint-modal{background:#fff;border-radius:1rem;width:100%;max-width:480px;padding:1.5rem;box-shadow:0 20px 50px #0000004d}.reprint-modal h2{color:var(--ffss-bleu);text-align:center;margin-bottom:1rem;font-size:1.2rem;font-weight:700}.reprint-modal .caisses-row{grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem;display:grid}.reprint-modal .caisses-row button{background:var(--ffss-bleu);color:#fff;cursor:pointer;border-radius:.6rem;min-height:60px;padding:1rem .5rem;font-weight:700;transition:background .15s}.reprint-modal .caisses-row button:hover:not(:disabled){background:var(--ffss-bleu-clair)}.reprint-modal .caisses-row button:disabled{opacity:.5;cursor:wait}.reprint-modal .cancel{color:#374151;cursor:pointer;background:#e5e7eb;border-radius:.5rem;width:100%;padding:.75rem;font-weight:600}.reprint-modal .cancel:hover{background:#d1d5db}.mes-ventes-pill{color:var(--ffss-bleu);cursor:pointer;border:2px solid var(--ffss-bleu);background:#fff;border-radius:999px;align-items:center;gap:.3rem;min-height:32px;padding:.35rem .8rem;font-size:.85rem;font-weight:700;display:inline-flex}.mes-ventes-pill:hover{background:#eaf0fa}.mes-ventes-backdrop{z-index:100;background:#00000073;position:fixed;inset:0}.mes-ventes-panel{z-index:101;background:#fff;flex-direction:column;width:100%;max-width:480px;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-8px 0 24px #00000040}.mes-ventes-header{background:var(--ffss-bleu);color:#fff;border-bottom:3px solid var(--ffss-jaune);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.mes-ventes-header h2{margin:0;font-size:1rem;font-weight:700}.mes-ventes-header .close{color:var(--ffss-bleu);cursor:pointer;background:#fff;border-radius:50%;width:32px;height:32px;font-size:1.1rem;font-weight:700}.mes-ventes-body{flex:1;padding:.75rem;overflow-y:auto}.mes-ventes-stats{background:var(--ffss-jaune);color:var(--ffss-bleu);text-align:center;padding:.5rem 1rem;font-size:.95rem;font-weight:700}.mes-ventes-item{background:#fff;border:1px solid #e5e7eb;border-radius:.6rem;margin-bottom:.5rem;padding:.6rem .75rem}.mes-ventes-item.annulee{opacity:.55;background:#fef2f2;border-color:#fecaca;text-decoration:line-through}.mes-ventes-item.rembourse{background:#fff7ed;border-color:#fed7aa}.mes-ventes-item-head{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.mes-ventes-item-id{color:var(--ffss-bleu);font-weight:700}.mes-ventes-item-total{font-weight:700}.mes-ventes-item-meta{color:#6b7280;margin-bottom:.4rem;font-size:.75rem}.mes-ventes-item-articles{color:#374151;margin-bottom:.5rem;font-size:.82rem;line-height:1.3}.mes-ventes-item-badges{gap:.3rem;margin-bottom:.4rem;font-size:.7rem;display:inline-flex}.mes-ventes-item-badges span{color:#991b1b;background:#fee2e2;border-radius:999px;padding:.1rem .4rem;font-weight:600}.mes-ventes-item-badges .rembourse{color:#9a3412;background:#fed7aa}.mes-ventes-item-actions{gap:.4rem;display:flex}.mes-ventes-item-actions button{cursor:pointer;border-radius:.4rem;flex:1;padding:.4rem .5rem;font-size:.78rem;font-weight:700}.mes-ventes-item-actions .annuler-btn{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.mes-ventes-item-actions .rembourser-btn{color:#9a3412;background:#fed7aa;border:1px solid #fdba74}.mes-ventes-item-actions button:disabled{opacity:.5;cursor:not-allowed}.code-modal input.code-input{letter-spacing:.05em;text-align:center;font-family:monospace;font-size:1.1rem}.vente-header{height:32px;color:var(--ffss-bleu);background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 .5rem;font-size:13px;display:flex}.vente-header .hdr-left{flex-direction:column;gap:1px;line-height:1;display:flex}.vente-header .hdr-user{color:#6b7280;font-size:11px;font-weight:500}.vente-header .hdr-ev{color:var(--ffss-bleu);font-size:13px;font-weight:500}.vente-header .hdr-right{align-items:center;gap:6px;display:flex}.vente-header .hdr-link{border-radius:4px;padding:2px 6px;font-size:13px;text-decoration:none}.vente-header .hdr-link-gris{color:#6b7280}.vente-header .hdr-link-noir{color:#111827;font-weight:500}.vente-header .hdr-link:hover{background:#f3f4f6}.vente-header .hdr-queue{color:#6b7280;font-size:11px}.vente-header .hdr-logout{color:var(--ffss-bleu);cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:4px;padding:2px 8px;font-size:13px}.vente-header .hdr-logout:hover{background:#f3f4f6}.vente-header .caisse-pill{color:#854f0b;background:#faeeda;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;line-height:1.4;text-decoration:none}.vente-header .caisse-pill.unset{color:#991b1b;background:#fee2e2}.vente-header #mes-ventes-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:13px}.vente-header #mes-ventes-btn:hover{background:#f3f4f6;border-radius:4px}.hdr-density{position:relative}.hdr-density-btn{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:4px;justify-content:center;align-items:center;padding:2px 4px;line-height:0;display:flex}.hdr-density-btn:hover{color:var(--ffss-bleu);background:#f3f4f6}.hdr-density-menu{z-index:200;background:#fff;border:1px solid #e5e7eb;border-radius:6px;min-width:180px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden;box-shadow:0 4px 12px #0000001a}.hdr-density-menu button{text-align:left;width:100%;color:var(--ffss-bleu);cursor:pointer;background:0 0;border:none;padding:8px 12px;font-size:13px;display:block}.hdr-density-menu button:hover{background:#f3f4f6}.hdr-density-menu button[aria-checked=true]:before{content:"✓ ";color:#378add;font-weight:700}.vente-tabs{background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-shrink:0;align-items:stretch;gap:4px;height:36px;padding:0 .5rem;display:flex;overflow-x:auto}.vente-tabs .cat-tab{color:var(--ffss-bleu);cursor:pointer;white-space:nowrap;background:#fff;border-bottom:3px solid #0000;border-radius:0;align-items:center;gap:5px;padding:0 12px;font-size:13px;font-weight:500;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.vente-tabs .cat-tab .tab-pill{color:#374151;background:#e5e7eb;border-radius:999px;padding:1px 6px;font-size:11px;font-weight:600}.vente-tabs .cat-tab:hover{color:var(--ffss-bleu);background:#fff}.vente-tabs .cat-tab.active{color:#0c447c;background:#e6f1fb;border-bottom-color:#378add}.vente-tabs .cat-tab.active .tab-pill{color:#fff;background:#378add}.vente-body{background:var(--ffss-bg);flex:1;grid-template-columns:1fr 270px;gap:0;min-height:0;display:grid;overflow:hidden}.vente-articles{padding:0;overflow-y:auto}.vente-articles .articles-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));align-content:start;gap:5px;padding:8px;display:grid}.vente-articles .section-titre{color:var(--ffss-bleu);grid-column:1/-1;align-items:center;gap:.5rem;margin:8px 0 4px;padding:2px 0;font-size:13px;font-weight:700;display:flex}.vente-articles .section-titre:first-child{margin-top:0}@media (max-width:1024px){.vente-body{grid-template-columns:1fr 240px}}@media (max-width:768px){.vente-body{grid-template-columns:1fr}.vente-panier{border-top:2px solid var(--ffss-bleu)}}.vente-panier{background:#fff;border-left:1px solid #e5e7eb;flex-direction:column;height:100%;display:flex;overflow:hidden}.panier-head{border-bottom:1px solid #e5e7eb;flex-shrink:0;padding:8px 12px}.panier-title{color:var(--ffss-bleu);font-size:14px;font-weight:700}.panier-subtitle{color:#6b7280;margin-top:1px;font-size:11px}.panier-lines{background:#f3f4f6;flex-direction:column;flex:1;gap:4px;min-height:0;padding:6px;display:flex;overflow-y:auto}.panier-empty{text-align:center;color:#9ca3af;padding:16px 6px;font-size:12px;font-style:italic}.panier-line{background:#fff;border-radius:6px;grid-template-columns:auto 1fr auto;align-items:center;gap:6px;padding:5px 7px;display:grid;box-shadow:0 1px 2px #0000000a}.panier-line .pl-emoji{font-size:18px;line-height:1}.panier-line .pl-info{min-width:0}.panier-line .pl-nom{color:var(--ffss-bleu);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.panier-line .pl-sub{color:#6b7280;font-size:10px;line-height:1.1}.panier-qty{background:#f3f4f6;border-radius:999px;align-items:center;gap:2px;padding:2px 4px;display:inline-flex}.panier-qty button{color:var(--ffss-bleu);cursor:pointer;background:0 0;border:none;border-radius:999px;width:18px;height:18px;font-size:14px;font-weight:700;line-height:1}.panier-qty button:hover{background:#fff}.panier-qty .pq-val{color:var(--ffss-bleu);text-align:center;min-width:16px;font-size:12px;font-weight:600}.panier-total{color:#fff;background:#042c53;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.panier-total-lbl{opacity:.85;font-size:13px}.panier-total-val{font-variant-numeric:tabular-nums;font-size:22px;font-weight:500}.panier-recu-zone{background:#f9fafb;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;flex-shrink:0;padding:8px 12px;display:none}.panier-recu-zone.visible{display:block}.recu-row,.monnaie-row{justify-content:space-between;align-items:center;padding:4px 0;display:flex}.recu-lbl,.monnaie-lbl{color:#6b7280;font-size:13px;font-weight:500}.recu-input-wrap{align-items:center;gap:4px;display:inline-flex;position:relative}.recu-input{color:#111827;text-align:right;font-variant-numeric:tabular-nums;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:110px;padding:8px 12px;font-size:16px;font-weight:500}.recu-input:focus{outline-offset:1px;border-color:#378add;outline:2px solid #378add}.recu-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.recu-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.recu-input{-moz-appearance:textfield}.recu-clear{color:#6b7280;cursor:pointer;background:#e5e7eb;border:none;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;font-weight:700;line-height:1;display:flex}.recu-clear:hover{color:#111827;background:#d1d5db}.monnaie-value{font-variant-numeric:tabular-nums;color:#111827;font-size:22px;font-weight:500}.monnaie-value.manque{color:#a32d2d}.monnaie-value.exact{color:#6b7280}.billets-grid{background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;grid-template-columns:repeat(6,1fr);gap:4px;padding:6px 8px;display:grid}.billets-grid.hidden{display:none}.billet-btn{color:#111827;cursor:pointer;font-variant-numeric:tabular-nums;background:#fff;border:1px solid #e5e7eb;border-radius:6px;height:48px;padding:0 4px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s,transform 80ms}.billet-btn:hover{background:#f3f4f6;border-color:#d1d5db}.billet-btn:active{transform:scale(.96)}.billet-btn.compte-juste{color:#0c447c;background:#e6f1fb;border-color:#bfdbfe;font-weight:600}.billet-btn.compte-juste:hover{background:#dbeafe;border-color:#93c5fd}.panier-pay{flex-shrink:0;grid-template-columns:1fr 1fr 1fr;gap:5px;padding:8px;display:grid}.panier-pay .pay-card{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:0;min-height:44px;padding:5px;transition:background .12s,color .12s,border-color .12s;display:flex}.panier-pay .pay-card .pay-emoji{background:0 0;font-size:16px;line-height:1}.panier-pay .pay-card .pay-lbl{font-size:11px;font-weight:600;line-height:1.2}.panier-pay .pay-card.active{color:#fff;background:#0c447c;border-color:#0c447c;box-shadow:0 1px 4px #0c447c4d}.panier-pay .pay-card.active .pay-lbl{color:#fff}.panier-actions{flex-shrink:0;grid-template-columns:auto 1fr;gap:5px;padding:0 8px 8px;display:grid}.panier-cancel{color:#6b7280;cursor:pointer;background:#f3f4f6;border:none;border-radius:8px;padding:0 12px;font-size:12px;font-weight:500}.panier-cancel:hover{color:#374151;background:#e5e7eb}.panier-valider{color:#fff;cursor:pointer;background:#0c447c;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;min-width:0;padding:10px;font-size:14px;font-weight:500;display:flex;overflow:hidden}.panier-valider .vld-lbl{white-space:nowrap;text-overflow:ellipsis;flex:auto;min-width:0;overflow:hidden}.panier-valider .vld-montant,.panier-valider .vld-sep{flex-shrink:0}.panier-valider:hover{background:#042c53}.panier-valider .vld-sep{opacity:.7}.panier-valider .vld-montant{font-variant-numeric:tabular-nums;font-weight:600}.vente-articles .article-btn{cursor:pointer;text-align:center;color:var(--ffss-bleu);aspect-ratio:1;background:#fff;border:1.5px solid #0000;border-top:3px solid #94a3b8;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;padding:6px 4px;font-weight:500;transition:transform .12s,box-shadow .15s,border-color .15s;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 2px #0000000a}.vente-articles .article-btn .emoji{line-height:1}.vente-articles .article-btn .nom{-webkit-line-clamp:2;word-break:break-word;-webkit-box-orient:vertical;font-size:11px;font-weight:500;line-height:1.15;display:-webkit-box;overflow:hidden}.vente-articles .article-btn .prix{color:var(--ffss-bleu);font-variant-numeric:tabular-nums;background:#e5e7eb;border-radius:999px;margin-top:2px;padding:1px 7px;font-size:11px;font-weight:700}.vente-articles .article-btn[data-cat=restauration]{border-top-color:#d85a30}.vente-articles .article-btn[data-cat=restauration] .prix{color:#993c1d;background:#faece7}.vente-articles .article-btn[data-cat=restauration]:hover{transform:translateY(-2px);box-shadow:0 0 0 2px #d85a3033,0 4px 8px #0000000d}.vente-articles .article-btn[data-cat=soft]{border-top-color:#378add}.vente-articles .article-btn[data-cat=soft] .prix{color:#0c447c;background:#e6f1fb}.vente-articles .article-btn[data-cat=soft]:hover{transform:translateY(-2px);box-shadow:0 0 0 2px #378add33,0 4px 8px #0000000d}.vente-articles .article-btn[data-cat=alcool]{border-top-color:#7f77dd}.vente-articles .article-btn[data-cat=alcool] .prix{color:#3c3489;background:#eeedfe}.vente-articles .article-btn[data-cat=alcool]:hover{transform:translateY(-2px);box-shadow:0 0 0 2px #7f77dd33,0 4px 8px #0000000d}.vente-articles .article-btn[data-cat=consigne]{border-top-color:#1d9e75}.vente-articles .article-btn[data-cat=consigne] .prix{color:#0f6e56;background:#e1f5ee}.vente-articles .article-btn[data-cat=consigne]:hover{transform:translateY(-2px);box-shadow:0 0 0 2px #1d9e7533,0 4px 8px #0000000d}.vente-articles .article-btn[data-cat=autre]{border-top-color:#94a3b8}.vente-articles .article-btn[data-cat=autre]:hover{transform:translateY(-2px);box-shadow:0 0 0 2px #94a3b833,0 4px 8px #0000000d}.vente-articles .article-btn:active{transform:translateY(0)scale(.97)}.vente-articles .section-titre .pill{color:#374151;background:#e5e7eb;border-radius:999px;padding:1px 6px;font-size:11px;font-weight:600}.vente-articles .section-titre[data-cat=restauration] .pill{color:#fff;background:#d85a30}.vente-articles .section-titre[data-cat=soft] .pill{color:#fff;background:#378add}.vente-articles .section-titre[data-cat=alcool] .pill{color:#fff;background:#7f77dd}.vente-articles .section-titre[data-cat=consigne] .pill{color:#fff;background:#1d9e75}body.density-confort .vente-articles .articles-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:7px;padding:10px}body.density-confort .vente-articles .article-btn{gap:4px;padding:10px 6px}body.density-confort .vente-articles .article-btn .emoji{font-size:20px;display:block}body.density-confort .vente-articles .article-btn .nom{font-size:12px}body.density-confort .vente-articles .article-btn .prix{padding:2px 8px;font-size:12px}body.density-compact .vente-articles .articles-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:4px;padding:6px}body.density-compact .vente-articles .article-btn{gap:2px;padding:4px 3px}body.density-compact .vente-articles .article-btn .emoji{display:none}body.density-compact .vente-articles .article-btn .nom{-webkit-line-clamp:2;font-size:10px}body.density-compact .vente-articles .article-btn .prix{padding:2px 8px;font-size:14px;font-weight:700}body.density-equilibre .vente-articles .article-btn{gap:2px;padding:6px 4px}body.density-equilibre .vente-articles .article-btn .emoji{opacity:.5;pointer-events:none;font-size:12px;position:absolute;top:4px;right:4px}body.density-equilibre .vente-articles .article-btn .nom{font-size:11px;font-weight:500}body.density-equilibre .vente-articles .article-btn .prix{padding:1px 7px;font-size:11px}.autre-modal-backdrop{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.autre-modal{background:#fff;border-radius:12px;width:calc(100% - 32px);max-width:360px;padding:24px;box-shadow:0 20px 50px #0000004d}.autre-modal h2{color:var(--ffss-bleu);text-align:center;margin:0 0 16px;font-size:16px;font-weight:700}.autre-modal-btn{width:100%;color:var(--ffss-bleu);cursor:pointer;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;align-items:center;gap:10px;margin-bottom:10px;padding:14px;font-size:14px;font-weight:600;transition:background .12s,border-color .12s,transform 80ms;display:flex}.autre-modal-btn:hover{background:#f3f4f6;border-color:#378add}.autre-modal-btn:active{transform:scale(.98)}.autre-modal-btn .am-emoji{font-size:20px}.autre-modal-conso-select{width:100%;color:var(--ffss-bleu);background:#fff;border:1.5px solid #378add;border-radius:8px;margin-top:-4px;margin-bottom:10px;padding:10px;font-size:13px;display:none}.autre-modal-conso-select.visible{display:block}.autre-modal-cancel{color:#6b7280;cursor:pointer;text-align:center;background:0 0;border:none;width:100%;margin-top:8px;padding:8px;font-size:13px}.autre-modal-cancel:hover{color:var(--ffss-bleu);text-decoration:underline}.autre-modal-error{color:#b91c1c;background:#fef2f2;border-radius:6px;margin-bottom:10px;padding:8px;font-size:12px;display:none}.autre-modal-error.visible{display:block}.vente-articles .article-btn{transition:transform .12s,box-shadow .18s,border-color .18s,background 80ms}.vente-articles .article-btn[data-cat=restauration]:hover{border-color:#d85a30;transform:translateY(-3px);box-shadow:0 0 0 3px #d85a3040,0 6px 14px #00000014}.vente-articles .article-btn[data-cat=soft]:hover{border-color:#378add;transform:translateY(-3px);box-shadow:0 0 0 3px #378add40,0 6px 14px #00000014}.vente-articles .article-btn[data-cat=alcool]:hover{border-color:#7f77dd;transform:translateY(-3px);box-shadow:0 0 0 3px #7f77dd40,0 6px 14px #00000014}.vente-articles .article-btn[data-cat=consigne]:hover{border-color:#1d9e75;transform:translateY(-3px);box-shadow:0 0 0 3px #1d9e7540,0 6px 14px #00000014}.vente-articles .article-btn[data-cat=autre]:hover{border-color:#94a3b8;transform:translateY(-3px);box-shadow:0 0 0 3px #94a3b840,0 6px 14px #00000014}.vente-articles .article-btn:active{transition:transform 50ms;transform:scale(.96)}@keyframes article-flash{0%{background:#c0dd97}to{background:#fff}}.vente-articles .article-btn.flash-added{animation:.2s ease-out article-flash}@keyframes panier-line-slidein{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.panier-line.slide-in{animation:.15s ease-out panier-line-slidein}@keyframes count-pulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.panier-subtitle.pulse{transform-origin:0;animation:.2s ease-in-out count-pulse;display:inline-block}.panier-qty{gap:4px;padding:3px 5px}.panier-qty button{width:36px;height:36px;font-size:18px;line-height:1}.panier-qty .pq-val{text-align:center;min-width:24px;font-size:14px;font-weight:500}.panier-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.panier-head-info{flex:1;min-width:0}.panier-undo{color:#6b7280;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #d1d5db;border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:11px;font-weight:400;transition:background .12s,color .12s,border-color .12s,transform 80ms}.panier-undo:hover{color:#374151;background:#f9fafb;border-color:#9ca3af}.panier-undo:active{transform:scale(.95)}.panier-undo.hidden{display:none}.panier-valider{transition:background .2s,color .2s;position:relative;overflow:hidden}.panier-valider.confirming{color:#fff;background:#ba7517;animation:2s linear forwards confirm-bg-fade}.panier-valider.confirming .confirm-progress{transform-origin:0;background:#ffffffb3;width:100%;height:3px;animation:2s linear forwards confirm-progress;position:absolute;bottom:0;left:0}@keyframes confirm-progress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}@keyframes confirm-bg-fade{0%,to{background:#ba7517}}.panier-valider:disabled{opacity:.55;cursor:not-allowed}.panier-valider.loading{pointer-events:none}@keyframes valider-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.panier-valider .vld-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:1s linear infinite valider-spin;display:inline-block}.panier-valider.mode-offert{background:#3b6d11}.panier-valider.mode-offert:hover{background:#2f560d}.panier-valider.mode-conso{background:#854f0b}.panier-valider.mode-conso:hover{background:#6b4009}.panier-valider.confirming.mode-offert,.panier-valider.confirming.mode-conso{background:#ba7517}.panier-title #ticket-id{font-variant-numeric:tabular-nums;color:var(--ffss-bleu)}.conn-indicator{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin:0 2px;transition:background .2s;display:inline-block;box-shadow:0 0 0 2px #ffffff80}.conn-indicator.conn-online{background:#16a34a}.conn-indicator.conn-slow{background:#f59e0b;animation:1.5s ease-in-out infinite conn-pulse}.conn-indicator.conn-offline{background:#dc2626;animation:.8s ease-in-out infinite conn-pulse}@keyframes conn-pulse{0%,to{opacity:1}50%{opacity:.4}}.offline-banner{color:#92400e;text-align:center;background:#fef3c7;border-bottom:2px solid #fcd34d;flex-shrink:0;padding:6px 12px;font-size:13px;font-weight:600}.offline-banner.hidden{display:none!important}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}