/*! jQuery UI - v1.9.2 - 2013-01-07
* http://jqueryui.com
* Includes: jquery.ui.core.css, jquery.ui.resizable.css, jquery.ui.selectable.css, jquery.ui.accordion.css, jquery.ui.autocomplete.css, jquery.ui.button.css, jquery.ui.datepicker.css, jquery.ui.dialog.css, jquery.ui.menu.css, jquery.ui.progressbar.css, jquery.ui.slider.css, jquery.ui.spinner.css, jquery.ui.tabs.css, jquery.ui.tooltip.css
* To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Verdana%2CArial%2Csans-serif&fwDefault=normal&fsDefault=1.1em&cornerRadius=4px&bgColorHeader=000000&bgTextureHeader=03_highlight_soft.png&bgImgOpacityHeader=40&borderColorHeader=aaaaaa&fcHeader=ebebeb&iconColorHeader=ebebeb&bgColorContent=f5f5f5&bgTextureContent=01_flat.png&bgImgOpacityContent=75&borderColorContent=aaaaaa&fcContent=222222&iconColorContent=ff6c00&bgColorDefault=e3e3e3&bgTextureDefault=07_diagonals_small.png&bgImgOpacityDefault=75&borderColorDefault=b3b3b3&fcDefault=444444&iconColorDefault=ff6c00&bgColorHover=fafafa&bgTextureHover=01_flat.png&bgImgOpacityHover=75&borderColorHover=ff6c00&fcHover=ff6c00&iconColorHover=ff6c00&bgColorActive=ff6c00&bgTextureActive=09_dots_small.png&bgImgOpacityActive=45&borderColorActive=ffaf0f&fcActive=fff&iconColorActive=ffffff&bgColorHighlight=fbf9ee&bgTextureHighlight=02_glass.png&bgImgOpacityHighlight=55&borderColorHighlight=ff9951&fcHighlight=44813b&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=02_glass.png&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=01_flat.png&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=01_flat.png&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px
* Copyright (c) 2013 jQuery Foundation and other contributors Licensed MIT */

/* Layout helpers
----------------------------------*/
.ui-helper-hidden { display: none; }
.ui-helper-hidden-accessible { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }
.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
.ui-helper-clearfix:before, .ui-helper-clearfix:after { content: ""; display: table; }
.ui-helper-clearfix:after { clear: both; }
.ui-helper-clearfix { zoom: 1; }
.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }


/* Interaction Cues
----------------------------------*/
.ui-state-disabled { cursor: default !important; }


/* Icons
----------------------------------*/

/* states and images */
.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }


/* Misc visuals
----------------------------------*/

/* Overlays */
.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.ui-resizable { position: relative;}
.ui-resizable-handle { position: absolute;font-size: 0.1px; display: block; }
.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; }
.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; }
.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; }
.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; }
.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; }
.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; }
.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; }
.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; }
.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; }
.ui-accordion .ui-accordion-header { display: block; cursor: pointer; position: relative; margin-top: 2px; padding: .5em .5em .5em .7em; zoom: 1; }
.ui-accordion .ui-accordion-icons { padding-left: 2.2em; }
.ui-accordion .ui-accordion-noicons { padding-left: .7em; }
.ui-accordion .ui-accordion-icons .ui-accordion-icons { padding-left: 2.2em; }
.ui-accordion .ui-accordion-header .ui-accordion-header-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; }
.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; overflow: auto; zoom: 1; }
.ui-autocomplete {
	position: absolute;
	top: 0;
	left: 0;
	cursor: default;
}

/* workarounds */
* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */
.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */
.ui-button, .ui-button:link, .ui-button:visited, .ui-button:hover, .ui-button:active { text-decoration: none; }
.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */
button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */
.ui-button-icons-only { width: 3.4em; } 
button.ui-button-icons-only { width: 3.7em; } 

/*button text element */
.ui-button .ui-button-text { display: block; line-height: 1.4;  }
.ui-button-text-only .ui-button-text { padding: .4em 1em; }
.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; }
.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; }
.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; }
.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; }
/* no icon support for input elements, provide padding by default */
input.ui-button { padding: .4em 1em; }

/*button icon element(s) */
.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; }
.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; }
.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; }
.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }

/*button sets*/
.ui-buttonset { margin-right: 7px; }
.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; }

/* workarounds */
button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */
.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; }
.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; }
.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
.ui-datepicker .ui-datepicker-prev { left:2px; }
.ui-datepicker .ui-datepicker-next { right:2px; }
.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
.ui-datepicker .ui-datepicker-next-hover { right:1px; }
.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px;  }
.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; }
.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
.ui-datepicker select.ui-datepicker-month, 
.ui-datepicker select.ui-datepicker-year { width: 49%;}
.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0;  }
.ui-datepicker td { border: 0; padding: 1px; }
.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; }
.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; }
.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }

/* with multiple calendars */
.ui-datepicker.ui-datepicker-multi { width:auto; }
.ui-datepicker-multi .ui-datepicker-group { float:left; }
.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; }

/* RTL support */
.ui-datepicker-rtl { direction: rtl; }
.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
.ui-datepicker-rtl .ui-datepicker-group { float:right; }
.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }

/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
.ui-datepicker-cover {
    position: absolute; /*must have*/
    z-index: -1; /*must have*/
    filter: mask(); /*must have*/
    top: -4px; /*must have*/
    left: -4px; /*must have*/
    width: 200px; /*must have*/
    height: 200px; /*must have*/
}.ui-dialog { position: absolute; top: 0; left: 0; padding: .2em; width: 300px; overflow: hidden; }
.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative;  }
.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; }
.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; }
.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; }
.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; }
.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; }
.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; }
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; }
.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; }
.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; }
.ui-draggable .ui-dialog-titlebar { cursor: move; }
.ui-menu { list-style:none; padding: 2px; margin: 0; display:block; outline: none; }
.ui-menu .ui-menu { margin-top: -3px; position: absolute; }
.ui-menu .ui-menu-item { margin: 0; padding: 0; zoom: 1; width: 100%; }
.ui-menu .ui-menu-divider { margin: 5px -2px 5px -2px; height: 0; font-size: 0; line-height: 0; border-width: 1px 0 0 0; }
.ui-menu .ui-menu-item a { text-decoration: none; display: block; padding: 2px .4em; line-height: 1.5; zoom: 1; font-weight: normal; }
.ui-menu .ui-menu-item a.ui-state-focus,
.ui-menu .ui-menu-item a.ui-state-active { font-weight: normal; margin: -1px; }

.ui-menu .ui-state-disabled { font-weight: normal; margin: .4em 0 .2em; line-height: 1.5; }
.ui-menu .ui-state-disabled a { cursor: default; }

/* icon support */
.ui-menu-icons { position: relative; }
.ui-menu-icons .ui-menu-item a { position: relative; padding-left: 2em; }

/* left-aligned */
.ui-menu .ui-icon { position: absolute; top: .2em; left: .2em; }

/* right-aligned */
.ui-menu .ui-menu-icon { position: static; float: right; }
.ui-progressbar { height:2em; text-align: left; overflow: hidden; }
.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; }.ui-slider { position: relative; text-align: left; }
.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; }
.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; }

.ui-slider-horizontal { height: .8em; }
.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; }
.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
.ui-slider-horizontal .ui-slider-range-min { left: 0; }
.ui-slider-horizontal .ui-slider-range-max { right: 0; }

.ui-slider-vertical { width: .8em; height: 100px; }
.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; }
.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; }
.ui-slider-vertical .ui-slider-range-min { bottom: 0; }
.ui-slider-vertical .ui-slider-range-max { top: 0; }.ui-spinner { position:relative; display: inline-block; overflow: hidden; padding: 0; vertical-align: middle; }
.ui-spinner-input { border: none; background: none; padding: 0; margin: .2em 0; vertical-align: middle; margin-left: .4em; margin-right: 22px; }
.ui-spinner-button { width: 16px; height: 50%; font-size: .5em; padding: 0; margin: 0; text-align: center; position: absolute; cursor: default; display: block; overflow: hidden; right: 0; }
.ui-spinner a.ui-spinner-button { border-top: none; border-bottom: none; border-right: none; } /* more specificity required here to overide default borders */
.ui-spinner .ui-icon { position: absolute; margin-top: -8px; top: 50%; left: 0; } /* vertical centre icon */
.ui-spinner-up { top: 0; }
.ui-spinner-down { bottom: 0; }

/* TR overrides */
.ui-spinner .ui-icon-triangle-1-s {
	/* need to fix icons sprite */
	background-position:-65px -16px;
}
.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; }
.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 0; margin: 1px .2em 0 0; border-bottom: 0; padding: 0; white-space: nowrap; }
.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; }
.ui-tabs .ui-tabs-nav li.ui-tabs-active { margin-bottom: -1px; padding-bottom: 1px; }
.ui-tabs .ui-tabs-nav li.ui-tabs-active a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-tabs-loading a { cursor: text; }
.ui-tabs .ui-tabs-nav li a, .ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */
.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; }
.ui-tooltip {
	padding: 8px;
	position: absolute;
	z-index: 9999;
	max-width: 300px;
	-webkit-box-shadow: 0 0 5px #aaa;
	box-shadow: 0 0 5px #aaa;
}
/* Fades and background-images don't work well together in IE6, drop the image */
* html .ui-tooltip {
	background-image: none;
}
body .ui-tooltip { border-width: 2px; }

/* Component containers
----------------------------------*/
.ui-widget { font-family: Verdana,Arial,sans-serif; font-size: 1.1em; }
.ui-widget .ui-widget { font-size: 1em; }
.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Verdana,Arial,sans-serif; font-size: 1em; }
.ui-widget-content { border: 1px solid #aaaaaa; background: #f5f5f5 url(images/ui-bg_flat_75_f5f5f5_40x100.png) 50% 50% repeat-x; color: #222222; }
.ui-widget-content a { color: #222222; }
.ui-widget-header { border: 1px solid #aaaaaa; background: #000000 url(images/ui-bg_highlight-soft_40_000000_1x100.png) 50% 50% repeat-x; color: #ebebeb; font-weight: bold; }
.ui-widget-header a { color: #ebebeb; }

/* Interaction states
----------------------------------*/
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #b3b3b3; background: #e3e3e3 url(images/ui-bg_diagonals-small_75_e3e3e3_40x40.png) 50% 50% repeat; font-weight: normal; color: #444444; }
.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #444444; text-decoration: none; }
.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #ff6c00; background: #fafafa url(images/ui-bg_flat_75_fafafa_40x100.png) 50% 50% repeat-x; font-weight: normal; color: #ff6c00; }
.ui-state-hover a, .ui-state-hover a:hover, .ui-state-hover a:link, .ui-state-hover a:visited { color: #ff6c00; text-decoration: none; }
.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #ffaf0f; background: #ff6c00 url(images/ui-bg_dots-small_45_ff6c00_2x2.png) 50% 50% repeat; font-weight: normal; color: #fff; }
.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #fff; text-decoration: none; }

/* Interaction Cues
----------------------------------*/
.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight  {border: 1px solid #ff9951; background: #fbf9ee url(images/ui-bg_glass_55_fbf9ee_1x400.png) 50% 50% repeat-x; color: #44813b; }
.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #44813b; }
.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #fef1ec url(images/ui-bg_glass_95_fef1ec_1x400.png) 50% 50% repeat-x; color: #cd0a0a; }
.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a; }
.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a; }
.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
.ui-priority-secondary, .ui-widget-content .ui-priority-secondary,  .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
.ui-state-disabled .ui-icon { filter:Alpha(Opacity=35); } /* For IE8 - See #6059 */

/* Icons
----------------------------------*/

/* states and images */
.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_ff6c00_256x240.png); }
.ui-widget-content .ui-icon {background-image: url(images/ui-icons_ff6c00_256x240.png); }
.ui-widget-header .ui-icon {background-image: url(images/ui-icons_ebebeb_256x240.png); }
.ui-state-default .ui-icon { background-image: url(images/ui-icons_ff6c00_256x240.png); }
.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_ff6c00_256x240.png); }
.ui-state-active .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); }
.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png); }
.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_cd0a0a_256x240.png); }

/* positioning */
.ui-icon-carat-1-n { background-position: 0 0; }
.ui-icon-carat-1-ne { background-position: -16px 0; }
.ui-icon-carat-1-e { background-position: -32px 0; }
.ui-icon-carat-1-se { background-position: -48px 0; }
.ui-icon-carat-1-s { background-position: -64px 0; }
.ui-icon-carat-1-sw { background-position: -80px 0; }
.ui-icon-carat-1-w { background-position: -96px 0; }
.ui-icon-carat-1-nw { background-position: -112px 0; }
.ui-icon-carat-2-n-s { background-position: -128px 0; }
.ui-icon-carat-2-e-w { background-position: -144px 0; }
.ui-icon-triangle-1-n { background-position: 0 -16px; }
.ui-icon-triangle-1-ne { background-position: -16px -16px; }
.ui-icon-triangle-1-e { background-position: -32px -16px; }
.ui-icon-triangle-1-se { background-position: -48px -16px; }
.ui-icon-triangle-1-s { background-position: -64px -16px; }
.ui-icon-triangle-1-sw { background-position: -80px -16px; }
.ui-icon-triangle-1-w { background-position: -96px -16px; }
.ui-icon-triangle-1-nw { background-position: -112px -16px; }
.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
.ui-icon-arrow-1-n { background-position: 0 -32px; }
.ui-icon-arrow-1-ne { background-position: -16px -32px; }
.ui-icon-arrow-1-e { background-position: -32px -32px; }
.ui-icon-arrow-1-se { background-position: -48px -32px; }
.ui-icon-arrow-1-s { background-position: -64px -32px; }
.ui-icon-arrow-1-sw { background-position: -80px -32px; }
.ui-icon-arrow-1-w { background-position: -96px -32px; }
.ui-icon-arrow-1-nw { background-position: -112px -32px; }
.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
.ui-icon-arrowthick-1-n { background-position: 0 -48px; }
.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
.ui-icon-arrow-4 { background-position: 0 -80px; }
.ui-icon-arrow-4-diag { background-position: -16px -80px; }
.ui-icon-extlink { background-position: -32px -80px; }
.ui-icon-newwin { background-position: -48px -80px; }
.ui-icon-refresh { background-position: -64px -80px; }
.ui-icon-shuffle { background-position: -80px -80px; }
.ui-icon-transfer-e-w { background-position: -96px -80px; }
.ui-icon-transferthick-e-w { background-position: -112px -80px; }
.ui-icon-folder-collapsed { background-position: 0 -96px; }
.ui-icon-folder-open { background-position: -16px -96px; }
.ui-icon-document { background-position: -32px -96px; }
.ui-icon-document-b { background-position: -48px -96px; }
.ui-icon-note { background-position: -64px -96px; }
.ui-icon-mail-closed { background-position: -80px -96px; }
.ui-icon-mail-open { background-position: -96px -96px; }
.ui-icon-suitcase { background-position: -112px -96px; }
.ui-icon-comment { background-position: -128px -96px; }
.ui-icon-person { background-position: -144px -96px; }
.ui-icon-print { background-position: -160px -96px; }
.ui-icon-trash { background-position: -176px -96px; }
.ui-icon-locked { background-position: -192px -96px; }
.ui-icon-unlocked { background-position: -208px -96px; }
.ui-icon-bookmark { background-position: -224px -96px; }
.ui-icon-tag { background-position: -240px -96px; }
.ui-icon-home { background-position: 0 -112px; }
.ui-icon-flag { background-position: -16px -112px; }
.ui-icon-calendar { background-position: -32px -112px; }
.ui-icon-cart { background-position: -48px -112px; }
.ui-icon-pencil { background-position: -64px -112px; }
.ui-icon-clock { background-position: -80px -112px; }
.ui-icon-disk { background-position: -96px -112px; }
.ui-icon-calculator { background-position: -112px -112px; }
.ui-icon-zoomin { background-position: -128px -112px; }
.ui-icon-zoomout { background-position: -144px -112px; }
.ui-icon-search { background-position: -160px -112px; }
.ui-icon-wrench { background-position: -176px -112px; }
.ui-icon-gear { background-position: -192px -112px; }
.ui-icon-heart { background-position: -208px -112px; }
.ui-icon-star { background-position: -224px -112px; }
.ui-icon-link { background-position: -240px -112px; }
.ui-icon-cancel { background-position: 0 -128px; }
.ui-icon-plus { background-position: -16px -128px; }
.ui-icon-plusthick { background-position: -32px -128px; }
.ui-icon-minus { background-position: -48px -128px; }
.ui-icon-minusthick { background-position: -64px -128px; }
.ui-icon-close { background-position: -80px -128px; }
.ui-icon-closethick { background-position: -96px -128px; }
.ui-icon-key { background-position: -112px -128px; }
.ui-icon-lightbulb { background-position: -128px -128px; }
.ui-icon-scissors { background-position: -144px -128px; }
.ui-icon-clipboard { background-position: -160px -128px; }
.ui-icon-copy { background-position: -176px -128px; }
.ui-icon-contact { background-position: -192px -128px; }
.ui-icon-image { background-position: -208px -128px; }
.ui-icon-video { background-position: -224px -128px; }
.ui-icon-script { background-position: -240px -128px; }
.ui-icon-alert { background-position: 0 -144px; }
.ui-icon-info { background-position: -16px -144px; }
.ui-icon-notice { background-position: -32px -144px; }
.ui-icon-help { background-position: -48px -144px; }
.ui-icon-check { background-position: -64px -144px; }
.ui-icon-bullet { background-position: -80px -144px; }
.ui-icon-radio-on { background-position: -96px -144px; }
.ui-icon-radio-off { background-position: -112px -144px; }
.ui-icon-pin-w { background-position: -128px -144px; }
.ui-icon-pin-s { background-position: -144px -144px; }
.ui-icon-play { background-position: 0 -160px; }
.ui-icon-pause { background-position: -16px -160px; }
.ui-icon-seek-next { background-position: -32px -160px; }
.ui-icon-seek-prev { background-position: -48px -160px; }
.ui-icon-seek-end { background-position: -64px -160px; }
.ui-icon-seek-start { background-position: -80px -160px; }
/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
.ui-icon-seek-first { background-position: -80px -160px; }
.ui-icon-stop { background-position: -96px -160px; }
.ui-icon-eject { background-position: -112px -160px; }
.ui-icon-volume-off { background-position: -128px -160px; }
.ui-icon-volume-on { background-position: -144px -160px; }
.ui-icon-power { background-position: 0 -176px; }
.ui-icon-signal-diag { background-position: -16px -176px; }
.ui-icon-signal { background-position: -32px -176px; }
.ui-icon-battery-0 { background-position: -48px -176px; }
.ui-icon-battery-1 { background-position: -64px -176px; }
.ui-icon-battery-2 { background-position: -80px -176px; }
.ui-icon-battery-3 { background-position: -96px -176px; }
.ui-icon-circle-plus { background-position: 0 -192px; }
.ui-icon-circle-minus { background-position: -16px -192px; }
.ui-icon-circle-close { background-position: -32px -192px; }
.ui-icon-circle-triangle-e { background-position: -48px -192px; }
.ui-icon-circle-triangle-s { background-position: -64px -192px; }
.ui-icon-circle-triangle-w { background-position: -80px -192px; }
.ui-icon-circle-triangle-n { background-position: -96px -192px; }
.ui-icon-circle-arrow-e { background-position: -112px -192px; }
.ui-icon-circle-arrow-s { background-position: -128px -192px; }
.ui-icon-circle-arrow-w { background-position: -144px -192px; }
.ui-icon-circle-arrow-n { background-position: -160px -192px; }
.ui-icon-circle-zoomin { background-position: -176px -192px; }
.ui-icon-circle-zoomout { background-position: -192px -192px; }
.ui-icon-circle-check { background-position: -208px -192px; }
.ui-icon-circlesmall-plus { background-position: 0 -208px; }
.ui-icon-circlesmall-minus { background-position: -16px -208px; }
.ui-icon-circlesmall-close { background-position: -32px -208px; }
.ui-icon-squaresmall-plus { background-position: -48px -208px; }
.ui-icon-squaresmall-minus { background-position: -64px -208px; }
.ui-icon-squaresmall-close { background-position: -80px -208px; }
.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
.ui-icon-grip-diagonal-se { background-position: -80px -224px; }


/* Misc visuals
----------------------------------*/

/* Corner radius */
.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; -khtml-border-top-left-radius: 4px; border-top-left-radius: 4px; }
.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; -khtml-border-top-right-radius: 4px; border-top-right-radius: 4px; }
.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; -khtml-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; }
.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; -khtml-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; }

/* Overlays */
.ui-widget-overlay { background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .3;filter:Alpha(Opacity=30); }
.ui-widget-shadow { margin: -8px 0 0 -8px; padding: 8px; background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .3;filter:Alpha(Opacity=30); -moz-border-radius: 8px; -khtml-border-radius: 8px; -webkit-border-radius: 8px; border-radius: 8px; }
/* ========================================
   PROSHOP CSS - MUUN GPAO
   Refactored structure organized by scope
   
   ORGANIZATION:
   ✓ GLOBALS: Rules that affect entire application
   ✓ COMPONENTS: Reusable UI elements  
   ✓ PAGES: Page-specific styles
   ✓ RESPONSIVE: Media queries
======================================== */

/* ========================================
   GLOBALS - RULES AFFECTING ENTIRE APPLICATION
   ⚠️ CAUTION: Changes here impact all pages
======================================== */

/* 1. IMPORTS & FONTS */
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&family=Heebo:wght@100;200;300;400;500;600;700;800;900&display=swap');

/* 2. CSS VARIABLES - Global Design Tokens */
:root {
  /* Colors */
  --color-black: #000000;
  --color-white: #ffffff;
  --color-primary: #007bff;
  --color-primary-hover: #0056b3;
  --color-success: #28a745;
  --color-warning: #ffc107;
  --color-danger: #dc3545;
  --color-focus: #007AFF;
  
  /* Grays */
  --color-gray-900: #1e293b;
  --color-gray-800: #333333;
  --color-gray-700: #475569;
  --color-gray-600: #64748b;
  --color-gray-500: #666666;
  --color-gray-400: #999999;
  --color-gray-300: #cccccc;
  --color-gray-200: #dee2e6;
  --color-gray-100: #f1f5f9;
  --color-gray-50: #f8f9fa;
  
  /* Backgrounds */
  --bg-body: #ffffff;
  --bg-section: #f8f9fa;
  --bg-card: #ffffff;
  --bg-hover: #f1f5f9;
  
  /* Borders */
  --border-light: #dee2e6;
  --border-medium: #ddd;
  
  /* Fonts */
  --font-body: "Open Sans", Helvetica, Arial, Lucida, sans-serif;
  --font-headings: "Heebo", Helvetica, Arial, Lucida, sans-serif;
  
  /* Spacing */
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  --spacing-2xl: 40px;
  --spacing-3xl: 60px;
  
  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.1);
  --shadow-md: 0 2px 10px rgba(0,0,0,0.1);
  --shadow-lg: 0 4px 20px rgba(0,0,0,0.15);
  --shadow-header: 0 2px 12px rgba(0,0,0,0.08);
  
  /* Transitions */
  --transition-fast: 0.2s ease;
  --transition-normal: 0.3s ease;
}

/* 3. BASE & RESET - Global Element Styles */
body {
  margin: 0;
  font-family: "Open Sans", Helvetica, Arial, Lucida, sans-serif;
  background-color: var(--bg-body);
  color: var(--color-gray-800);
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Heebo", Helvetica, Arial, Lucida, sans-serif;
  margin: 0;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: var(--transition-fast);
}

a:hover {
  color: var(--color-primary-hover);
}

/* 4. LAYOUT UTILITIES - Global Layout Classes */
.container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--spacing-lg);
}

.main-container {
  /* Inherit from .container */
}

/* 5. GLOBAL BUTTONS - System-wide Button Styles */
.btn {
  display: inline-block;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: 4px;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  border: none;
  transition: var(--transition-fast);
  text-align: center;
}

.btn-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.btn-primary:hover {
  background-color: var(--color-primary-hover);
  color: var(--color-white);
}

.btn-secondary {
  background-color: var(--color-gray-600);
  color: var(--color-white);
}

.btn-secondary:hover {
  background-color: #5a6268;
}

.btn-large {
  padding: 12px var(--spacing-lg);
  font-size: 1rem;
  margin-right: 15px;
  margin-bottom: 10px;
}

.btn-compact {
  padding: 6px 12px;
  font-size: 0.85rem;
  flex: 1;
}

.btn-sm {
  padding: 6px 12px;
  font-size: 0.9rem;
}

/* Black Button Base Style - Common for header and forms */
.btn-black {
  background: var(--color-black);
  color: var(--color-white);
  text-decoration: none;
  font-weight: 700;
  letter-spacing: 1px;
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: opacity var(--transition-fast);
  text-transform: uppercase;
}

.btn-black:hover {
  color: var(--color-white);
  opacity: 0.8;
}

/* Header-specific Button Variants - All consolidated below */

.btn-header-compact {
  padding: var(--spacing-sm) var(--spacing-md);
  font-size: 14px;
  transition: opacity var(--transition-fast);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn-header-compact:hover {
  opacity: 0.8;
}

.btn-header-main {
  padding: 14px 30px;
  font-size: 16px;
  display: inline-block;
  transition: transform var(--transition-fast);
  margin-bottom: var(--spacing-lg);
}

.btn-header-main:hover {
  transform: scale(1.02);
}

/* 6. GLOBAL FORMS - System-wide Form Styles */
.form-group {
  margin-bottom: var(--spacing-lg);
}

.form-group label {
  display: block;
  margin-bottom: 5px;
  font-weight: 500;
  color: var(--color-gray-800);
}

.form-control {
  width: 100%;
  padding: 12px;
  border: 1px solid var(--border-medium);
  border-radius: 4px;
  font-size: 16px;
  box-sizing: border-box;
}

.form-control:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(0,123,255,0.25);
}

/* ========================================
   COMPONENTS - REUSABLE UI ELEMENTS
   ✅ Safe: Component-specific modifications
======================================== */

/* Layout Components */
.col-right::before {
  content: '';
  display: block;
  width: 15px;
  height: 4px;
  background-color: #000000;
  margin-bottom: 20px;
}

/* HEADER COMPONENT */
.proshop-header {
  background: var(--color-white);
  box-shadow: var(--shadow-header);
  padding: 0;
  position: sticky;
  top: 0;
  z-index: 1000;
}

.proshop-header .logo-section h1 {
  margin: 0;
}

.proshop-header .logo-section a {
  text-decoration: none;
  display: flex;
  align-items: end;
  gap: 12px;
  color: var(--color-gray-900);
}

.proshop-header .logo {
  height: 36px;
  width: auto;
  display: block;
}

.proshop-header .company {
  font-weight: 600;
  color: var(--color-gray-900);
  font-size: 0.95rem;
}

.proshop-header .btn-logout {
  color: var(--color-gray-600);
  font-size: 1.2rem;
  padding: var(--spacing-sm);
  border-radius: 6px;
  transition: var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
}

.proshop-header .btn-logout:hover {
  background-color: var(--bg-hover);
  color: var(--color-gray-700);
  transform: translateY(-1px);
}

/* Modern Header Component */
.proshop-header-new {
  background: var(--color-white);
  height: 60px;
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--shadow-sm);
}

.header-container {
  max-width: 1400px;
  margin: 0 auto;
  height: 100%;
  padding: 0 var(--spacing-lg);
}

/* Desktop header layout */
.header-desktop {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--spacing-lg);
  height: 100%;
}

.header-desktop .header-left {
  grid-column: 1;
  justify-self: start;
  display: flex;
  align-items: center;
}

.header-desktop .header-center {
  grid-column: 2;
  justify-self: center;
  display: flex;
  align-items: center;
}

.header-desktop .header-right {
  grid-column: 3;
  justify-self: end;
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
}

/* Mobile header layout - hidden by default */
.header-mobile {
  display: none;
}

.logo-link {
  text-decoration: none;
  color: var(--color-black);
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 3px;
}

.logo-image {
  height: 40px;
  width: auto;
  display: block;
}

/* Header Search Component */
.search-form {
  position: relative;
  display: flex;
  align-items: center;
}

.search-input {
  width: 220px;
  height: 24px;
  border: none;
  border-bottom: 1px solid var(--color-gray-300);
  background: transparent;
  padding: 0 40px 0 var(--spacing-md);
  font-size: 14px;
  color: var(--color-gray-800);
  outline: none;
  text-align: left;
  transition: border-bottom-color var(--transition-normal);
}

.search-input::placeholder {
  color: var(--color-gray-500);
}

.search-input:focus {
  border-bottom-color: var(--color-gray-500);
}

.search-submit {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-500);
  transition: color var(--transition-fast);
}

.search-submit:hover {
  color: var(--color-gray-800);
}

.search-submit svg {
  width: 16px;
  height: 16px;
}

.search-input-container {
  position: relative;
}

.search-input-container .search-input {
  width: 100%;
  padding: 12px;
  border: 1px solid var(--border-medium);
  border-radius: 4px;
  font-size: 16px;
  box-sizing: border-box;
}

.search-clear-btn {
  position: absolute;
  right: var(--spacing-sm);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 18px;
  color: var(--color-gray-400);
  cursor: pointer;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: var(--transition-fast);
}

.search-clear-btn:hover {
  background-color: var(--bg-section);
  color: var(--color-gray-500);
}

.search-btn {
  width: 100%;
  margin-top: 10px;
  padding: 10px;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
}

.search-btn:hover {
  background: var(--color-primary-hover);
}

/* Header User Navigation */
.header-user-nav {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.header-user-nav .nav-link {
  color: var(--color-gray-800);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  transition: color var(--transition-fast);
}

.header-user-nav .nav-link:hover {
  color: var(--color-gray-600);
}

.header-user-nav .nav-separator {
  color: var(--color-gray-400);
  font-size: 13px;
}

.panier-link {
  position: relative;
}

.panier-count {
  position: absolute;
  top: -8px;
  right: -8px;
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  color: var(--color-white);
  border-radius: 50%;
  min-width: 20px;
  height: 20px;
  font-size: 11px;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  box-shadow: 0 2px 4px rgba(239, 68, 68, 0.4);
  border: 2px solid var(--color-white);
}

/* FOOTER COMPONENT */
.company-footer {
  text-align: center;
  margin-top: var(--spacing-3xl);
  padding: var(--spacing-2xl) var(--spacing-lg);
  border-top: 1px solid #EEEEEE;
  background: var(--color-white);
}

.company-footer p {
  font-size: 10px;
  color: var(--color-gray-500);
  margin: 0;
  font-weight: 400;
}

/* NAVIGATION COMPONENT */
.breadcrumb {
  padding: 15px 0;
  margin-bottom: var(--spacing-lg);
  font-size: 0.8rem;
  text-transform: uppercase;
}

.breadcrumb a {
  color: var(--color-gray-800);
  text-decoration: none;
}

.breadcrumb a:hover {
  text-decoration: underline;
}

.breadcrumb .separator {
  margin: 0 var(--spacing-sm);
  color: var(--color-gray-500);
}

.breadcrumb .current {
  color: var(--color-gray-800);
  font-weight: 500;
}

/* Categories Navigation Component */
.categories-nav {
  margin-bottom: 30px;
}

.categories-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.categories-list li {
  margin-bottom: 5px;
}

.categories-list a {
  display: block;
  padding: var(--spacing-sm) 12px;
  text-decoration: none;
  color: var(--color-gray-700);
  border-radius: 4px;
  transition: var(--transition-normal);
}

.categories-list a:hover {
  background: #e9ecef;
}

.categories-list a.active {
  background: var(--color-primary);
  color: var(--color-white);
  font-weight: 500;
}


/* PAGINATION COMPONENT */
.pagination {
  display: flex;
  justify-content: center;
  gap: var(--spacing-sm);
  margin: var(--spacing-2xl) 0;
}

.pagination-list {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 5px;
}

.pagination-link {
  padding: var(--spacing-sm) 12px;
  color: var(--color-primary);
  text-decoration: none;
  border: 1px solid var(--border-medium);
  border-radius: 4px;
  transition: var(--transition-fast);
}

.pagination-link:hover {
  background-color: #e9ecef;
}

.pagination-link.active {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

/* ========================================
   PAGES - PAGE-SPECIFIC STYLES
   ✅ Safe: Page-specific modifications only
======================================== */

/* LOGIN PAGE */
.proshop-login {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 80vh;
  background-color: var(--bg-section);
}

.proshop-login .login-container {
  background: var(--color-white);
  padding: var(--spacing-2xl);
  border-radius: var(--spacing-sm);
  box-shadow: var(--shadow-md);
  max-width: 400px;
  width: 100%;
}

.proshop-login .login-container h1 {
  text-align: center;
  margin-bottom: 10px;
  color: var(--color-gray-800);
}

.proshop-login .login-container p {
  text-align: center;
  color: var(--color-gray-500);
  margin-bottom: 30px;
}

.proshop-login .error-message {
  background-color: #f8d7da;
  color: #721c24;
  padding: 12px;
  border-radius: 4px;
  margin-bottom: var(--spacing-lg);
  border: 1px solid #f5c6cb;
}

.proshop-login .login-info {
  margin-top: 30px;
  text-align: center;
}

.proshop-login .login-info p {
  color: var(--color-gray-500);
  font-size: 14px;
  margin: 0;
}

/* HOME PAGE - Legacy */
.proshop-accueil {
  padding: var(--spacing-lg) 0;
}

.proshop-accueil .welcome-section h1 {
  margin: 0 0 10px 0;
  font-size: 2.5rem;
}

.proshop-accueil .client-info h2 {
  margin: 0 0 var(--spacing-lg) 0;
  color: var(--color-gray-800);
}

/* HOME PAGE - Modern */
.hero-section {
  display: flex;
  gap: var(--spacing-3xl);
  margin-top: var(--spacing-3xl);
}

.image-column {
  flex: 1;
  justify-content: center;
  align-items: center;
}

.product-image-container {
  background: var(--color-white);
  border-radius: var(--spacing-sm);
}

.content-column {
  flex: 1;
  margin-right: var(--spacing-3xl);
}

/* Fix image proportions on homepage */
.proshop-accueil-new .product-image {
  width: 100%;
  height: auto;
  aspect-ratio: unset;
  background: transparent;
}

.proshop-accueil-new .product-image img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.established-badge {
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: var(--spacing-2xl);
  font-weight: 700;
}

.intro-section {
  margin-bottom: var(--spacing-lg);
}

.intro-text {
  font-size: 16px;
  color: var(--color-gray-800);
  line-height: 1.4;
  margin: 0;
  font-weight: 400;
}

.description-blocks {
  margin-bottom: var(--spacing-2xl);
}

.description-block {
  margin-bottom: var(--spacing-xl);
}

.description-block:last-child {
  margin-bottom: 0;
}

.block-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-black);
  margin: 0 0 12px 0;
}

.block-text {
  font-size: 14px;
  color: var(--color-gray-800);
  line-height: 1.5;
  text-align: justify;
  margin: 0;
  font-weight: 400;
}

.action-section {
  margin-top: var(--spacing-2xl);
}

.terms-link {
  display: block;
  color: var(--color-black);
  font-size: 12px;
  text-decoration: underline;
  font-weight: 400;
  transition: color var(--transition-fast);
}

.terms-link:hover {
  color: var(--color-gray-500);
}

/* Contact and Social - Home Page Specific */
.contact-section {
  margin-top: var(--spacing-2xl);
}

.social-icons {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: var(--spacing-md);
}

.instagram-link {
  color: var(--color-black);
  text-decoration: none;
}

.instagram-icon {
  width: 24px;
  height: 24px;
}

.instagram-icon svg {
  width: 100%;
  height: 100%;
  color: var(--color-black);
}

.website-link {
  color: var(--color-black);
  text-decoration: none;
  font-size: 12px;
  font-weight: 400;
}

.website-link:hover {
  text-decoration: underline;
}

.contact-info {
  font-size: 12px;
  color: var(--color-gray-800);
}

.contact-info p {
  margin: 4px 0;
}

/* Contact section moved to bottom of content column */
.contact-section.moved-to-bottom {
  margin-top: var(--spacing-2xl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--color-gray-300);
}

/* ORDERS PAGE */
.commandes-page {
  max-width: 800px;
  margin: 0 auto;
  padding: var(--spacing-lg);
}

.commandes-page h1 {
  color: var(--color-gray-800);
  margin-bottom: 30px;
}

.no-commandes {
  text-align: center;
  padding: var(--spacing-2xl);
  background: var(--bg-section);
  border-radius: 5px;
}

.commande-item {
  background: var(--color-white);
  border: 1px solid var(--border-medium);
  margin-bottom: var(--spacing-lg);
  border-radius: 5px;
  overflow: hidden;
}

.commande-header {
  background: var(--bg-section);
  padding: 15px;
  border-bottom: 1px solid var(--border-medium);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.commande-header h3 {
  margin: 0;
  color: var(--color-gray-800);
}

.commande-date {
  font-size: 14px;
  color: var(--color-gray-500);
}

.commande-details {
  padding: 15px;
}

.commande-details > div {
  margin-bottom: 10px;
}

.commande-details > div:last-child {
  margin-bottom: 0;
}

.commande-total {
  font-size: 18px;
  color: #2c5aa0;
}

.statut {
  padding: 4px var(--spacing-sm);
  border-radius: 3px;
  font-size: 12px;
  font-weight: bold;
  text-transform: uppercase;
}

.statut.validee {
  background: #e7f3ff;
  color: #2c5aa0;
}

.statut.production {
  background: #fff3e0;
  color: #f57c00;
}

.statut.expediee {
  background: #f3e5f5;
  color: #8e24aa;
}

.statut.facturee {
  background: #e8f5e8;
  color: #2e7d32;
}

.commande-commentaires {
  background: var(--bg-section);
  padding: 10px;
  border-radius: 3px;
  font-style: italic;
}

/* 404 PAGE */
.proshop-404 {
  padding: var(--spacing-3xl) 0;
  text-align: center;
}

.proshop-404 .error-content h1 {
  font-size: 3rem;
  color: var(--color-danger);
  margin-bottom: var(--spacing-lg);
}

.proshop-404 .error-content p {
  font-size: 1.2rem;
  color: var(--color-gray-500);
  margin-bottom: 30px;
}

/* CATALOGUE PAGE */
.proshop-catalogue {
  padding: var(--spacing-lg) 0;
}

.catalogue-layout {
  display: grid;
  grid-template-columns: 250px 1fr;
  gap: 30px;
}

.catalogue-sidebar {
  border-radius: var(--spacing-sm);
  height: fit-content;
  width: 100%;
}

/* Categories Navigation Styles */
.catalogue-sidebar .categories-nav {
  border-radius: 4px;
  margin-bottom: 160px; /* Espace pour le cadre fixe */
}

.catalogue-sidebar .categories-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.catalogue-sidebar .category-item {
  margin-bottom: 0px;
}

.catalogue-sidebar .category-link {
  text-decoration: none;
  color: #333;
  font-weight: 700;
  font-size: 16px;
  padding: 8px 12px;
  display: block;
  border-radius: 3px;
  transition: background-color 0.2s;
}

.catalogue-sidebar .category-link:hover {
  background-color: #e9e9e9;
}

.catalogue-sidebar .category-link.active {
  background-color: var(--color-gray-100);
  color: var(--color-gray-800);
}

/* Delivery Info Styles - Consolidated above with main .catalogue-sidebar */

.catalogue-sidebar .delivery-info {
  background-color: white;
  padding: 15px;
  font-size: 12px;
  line-height: 1.5;
  border-top: 1px solid #eee;
  box-shadow: 0 -2px 10px rgba(0,0,0,0.1);
  position: fixed;
  bottom: 0;
  left: calc(50% - 700px); /* Centre de l'écran moins la moitié du container */
  width: 220px; /* 250px - 30px de padding */
  z-index: 1000;
}

.catalogue-sidebar .delivery-info div {
  margin-bottom: 3px;
}

.catalogue-sidebar .delivery-info a {
  color: black;
  text-decoration: none;
}

.catalogue-sidebar .delivery-info a:hover {
  text-decoration: underline;
}

.catalogue-sidebar .instagram-link {
  margin-top: 10px;
}

.catalogue-sidebar .instagram-link a {
  color: #333;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  transition: color 0.2s;
}

.catalogue-sidebar .instagram-link a:hover {
  color: #E4405F;
}

.catalogue-sidebar h3 {
  margin: 0 0 15px 0;
  color: var(--color-gray-800);
  font-size: 1.1rem;
}

.search-box {
  margin-bottom: 30px;
}

.sort-select {
  width: 100%;
  padding: var(--spacing-sm);
  border: 1px solid var(--border-medium);
  border-radius: 4px;
  font-size: 14px;
}

.catalogue-main {
  min-height: 400px;
}

.catalogue-header {
  margin-bottom: 30px;
}

.catalogue-header h1 {
  margin: 0 0 5px 0;
  color: var(--color-gray-800);
}

.results-count {
  margin: 0;
  color: var(--color-gray-500);
  font-size: 0.9rem;
}

.no-products {
  text-align: center;
  padding: var(--spacing-3xl) var(--spacing-lg);
}

.no-products p {
  color: var(--color-gray-500);
  font-size: 1.1rem;
  margin-bottom: var(--spacing-lg);
}

/* CATEGORY GRID STYLES */
.categories-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-2xl);
}

.category-card {
  background: var(--color-white);
  overflow: hidden;
  transition: transform var(--transition-fast);
}

.category-card:hover {
  transform: translateY(-2px);
}

/* SEARCH RESULTS STYLES */
.search-results-header {
  margin-bottom: var(--spacing-lg);
}

.search-results-header h2 {
  font-size: 1.5rem;
  color: var(--color-gray-800);
  margin-bottom: var(--spacing-sm);
}

.search-results-header p {
  color: var(--color-gray-600);
  margin: 0;
}

.no-results {
  text-align: center;
  padding: var(--spacing-2xl);
  background: var(--color-gray-50);
  border-radius: 8px;
  margin: var(--spacing-lg) 0;
}

.no-results p {
  color: var(--color-gray-600);
  margin-bottom: var(--spacing-lg);
}

/* PRODUCT GRID STYLES */
.products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-2xl);
}

.product-card {
  background: var(--color-white);
  overflow: hidden;
  transition: transform var(--transition-fast);
}

.product-card:hover {
  transform: translateY(-2px);
}

.product-image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: var(--color-gray-100);
}

.product-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-normal);
}

.product-card:hover .product-image img {
  transform: scale(1.05);
}

.product-info {
  padding: var(--spacing-md);
}

.product-title {
  margin-bottom: var(--spacing-sm);
}

.product-title a {
  text-decoration: none;
  color: inherit;
  display: block;
}

.product-name {
  display: block;
  font-weight: 600;
  color: var(--color-gray-800);
  margin-bottom: var(--spacing-xs);
  line-height: 1.3;
}

.product-code {
  display: block;
  font-size: 0.85rem;
  color: var(--color-gray-600);
  margin-bottom: var(--spacing-sm);
}

.product-price {
  font-weight: 600;
  color: var(--color-gray-800);
  font-size: 1.1rem;
}

/* PAGINATION STYLES - Additional pagination elements */

.page-link, .page-current {
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-light);
  text-decoration: none;
  color: var(--color-gray-700);
  transition: var(--transition-fast);
}

.page-link:hover {
  background: var(--color-gray-100);
  color: var(--color-gray-800);
}

.page-current {
  background: var(--color-primary);
  color: white;
  border-color: var(--color-primary);
}

.category-image {
  position: relative;
  width: 100%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.category-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

.category-info {
  padding: var(--spacing-lg);
}

.category-title {
  margin: 0 0 10px 0;
  font-size: 0.85rem;
  text-align: center;
}

.category-title a {
  color: var(--color-black);
  text-decoration: none;
  font-weight: normal;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.category-title a:hover {
  color: var(--color-black);
}

.category-name {
  font-weight: normal;
  font-size: 0.85rem;
}

.category-price {
  color: var(--color-black);
  font-weight: bold;
  font-size: 0.85rem;
}

.no-categories {
  text-align: center;
  padding: var(--spacing-3xl) var(--spacing-lg);
}

.no-categories p {
  color: var(--color-gray-500);
  font-size: 1.1rem;
  margin-bottom: var(--spacing-lg);
}

/* Advanced Search - Catalogue Page */
.advanced-search {
  margin-top: 15px;
}

.toggle-advanced {
  background: none;
  border: none;
  color: var(--color-primary);
  cursor: pointer;
  font-size: 0.9em;
  padding: 0;
  text-align: left;
  width: 100%;
}

.toggle-advanced:hover {
  text-decoration: underline;
}

.toggle-advanced .arrow {
  transition: transform var(--transition-normal);
  font-size: 0.8em;
  margin-left: 5px;
}

.toggle-advanced.open .arrow {
  transform: rotate(180deg);
}

.advanced-fields {
  margin-top: 10px;
  padding: 15px;
  background: var(--bg-section);
  border-radius: 4px;
}

.field-group {
  margin-bottom: 15px;
}

.field-group:last-child {
  margin-bottom: 0;
}

.field-group label {
  display: block;
  margin-bottom: 5px;
  font-size: 0.9em;
  font-weight: 500;
  color: var(--color-gray-700);
}

.field-group input {
  width: 100%;
  padding: var(--spacing-sm);
  border: 1px solid var(--border-medium);
  border-radius: 4px;
  font-size: 0.9em;
  box-sizing: border-box;
}

/* CART PAGE */
.proshop-panier {
  padding: var(--spacing-lg) 0;
}

.panier-vide {
  text-align: center;
  padding: var(--spacing-3xl) var(--spacing-lg);
}

.panier-form {
  background: var(--color-white);
  border-radius: var(--spacing-sm);
  overflow: hidden;
}

.panier-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--spacing-lg);
}

.panier-table th {
  padding: 15px;
  text-align: left;
  font-weight: 600;
  border-bottom: 2px solid var(--border-light);
}

.panier-table td {
  padding: 15px;
  border-bottom: 1px solid var(--border-light);
}

.panier-table .produit {
  min-width: 250px;
}

.panier-table .produit-code {
  color: var(--color-gray-500);
  font-size: 0.9em;
  margin-top: 5px;
}

.panier-table .quantite-input {
  width: 60px;
  padding: 5px;
  border: 1px solid var(--border-medium);
  border-radius: 4px;
  text-align: center;
}

.panier-table .btn-supprimer {
  color: var(--color-danger);
  text-decoration: none;
  font-size: 0.9em;
}

.panier-table .btn-supprimer:hover {
  text-decoration: underline;
}

.panier-resume {
  background: var(--bg-section);
  padding: var(--spacing-lg);
}

.panier-resume .total-ligne {
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
}

.panier-resume .total-ht {
  font-weight: bold;
  font-size: 1.1em;
  padding-top: 10px;
}

.panier-validation {
  background: var(--color-white);
  padding: var(--spacing-lg);
  border-top: 1px solid var(--border-light);
}

.commentaire-section {
  margin-bottom: var(--spacing-lg);
}

.commentaire-section label {
  display: block;
  margin-bottom: 5px;
  font-weight: 500;
}

.commentaire-section textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--border-medium);
  border-radius: 4px;
  resize: vertical;
  box-sizing: border-box;
}

.validation-actions {
  display: flex;
  gap: 15px;
  justify-content: flex-end;
}

.panier-non-validable {
  background: #fff3cd;
  color: #856404;
  padding: var(--spacing-lg);
  border-radius: 4px;
  text-align: center;
}

.panier-non-validable .erreur {
  margin: 0 0 15px 0;
}

/* PRODUCT DETAIL PAGE */
.proshop-produit {
  padding: var(--spacing-lg) 0;
}

.produit-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-2xl);
  align-items: start;
  margin-bottom: var(--spacing-2xl);
}

.produit-image {
  background: var(--bg-section);
  border-radius: var(--spacing-sm);
  overflow: hidden;
}

.produit-image img {
  width: 100%;
  height: auto;
  max-height: 500px;
  object-fit: contain;
  display: block;
}

.produit-title {
  margin: 0 0 15px 0;
  font-size: 2rem;
  color: var(--color-gray-800);
  line-height: 1.2;
}

.produit-code {
  margin: 0 0 10px 0;
  color: var(--color-gray-500);
  font-size: 1rem;
}

.produit-subtitle {
  margin: 0 0 var(--spacing-lg) 0;
  color: var(--color-gray-500);
  font-size: 1.1rem;
}

.produit-price {
  margin: var(--spacing-lg) 0;
  padding: var(--spacing-lg);
  background: var(--bg-section);
  border-radius: var(--spacing-sm);
}

.produit-price .price-main {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-success);
  margin-bottom: var(--spacing-sm);
}

.produit-price .price-public {
  font-size: 1rem;
  color: var(--color-gray-500);
  font-weight: 500;
}

.produit-price .price-note {
  display: block;
  margin-top: 5px;
  color: var(--color-gray-500);
  font-size: 0.9rem;
}

.produit-price .price-na {
  font-size: 1.2rem;
  color: var(--color-warning);
  font-style: italic;
}

.produit-category {
  margin: 15px 0;
}

.produit-category .category-label {
  font-weight: 500;
  color: var(--color-gray-600);
  margin-right: 10px;
}

.produit-category .category-link {
  color: var(--color-primary);
  text-decoration: none;
}

.produit-category .category-link:hover {
  text-decoration: underline;
}

.produit-description {
  margin: var(--spacing-lg) 0;
}

.produit-description h3 {
  margin: 0 0 10px 0;
  color: var(--color-gray-800);
}

.produit-description .description-content {
  line-height: 1.6;
  color: var(--color-gray-600);
}

.produit-actions {
  margin-top: 30px;
}

.quantity-selector {
  margin-bottom: var(--spacing-lg);
}

.quantity-selector label {
  display: block;
  margin-bottom: 5px;
  font-weight: 500;
  color: var(--color-gray-600);
}

.quantity-selector input {
  width: 80px;
  padding: var(--spacing-sm);
  border: 1px solid var(--border-medium);
  border-radius: 4px;
  text-align: center;
}

/* Product Variations & Similar Products - Product Page Specific */
.produit-variations,
.produits-similaires {
  margin: var(--spacing-2xl) 0;
}

.produit-variations h2,
.produits-similaires h2 {
  margin: 0 0 10px 0;
  color: var(--color-gray-800);
}

.variations-intro,
.similaires-intro {
  margin: 0 0 var(--spacing-lg) 0;
  color: var(--color-gray-500);
}

.variations-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: var(--spacing-lg);
}

.similaires-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--spacing-lg);
}

.variation-card,
.similaire-card {
  background: var(--color-white);
  border-radius: var(--spacing-sm);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  transition: transform var(--transition-fast);
}

.variation-card:hover,
.similaire-card:hover {
  transform: translateY(-2px);
}

.variation-image,
.similaire-image {
  background: var(--bg-section);
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.similaire-image {
  height: 120px;
}

.variation-image img,
.similaire-image img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.variation-info,
.similaire-info {
  padding: 15px;
}

.variation-title,
.similaire-title {
  margin: 0 0 5px 0;
  font-size: 0.9rem;
}

.variation-title a,
.similaire-title a {
  color: var(--color-gray-800);
  text-decoration: none;
}

.variation-title a:hover,
.similaire-title a:hover {
  color: var(--color-primary);
}

.variation-code,
.similaire-code {
  margin: 0 0 10px 0;
  color: var(--color-gray-500);
}

.variation-code {
  font-size: 0.9rem;
}

.similaire-code {
  font-size: 0.8rem;
}

.variation-price,
.similaire-price {
  margin: 10px 0;
}

.variation-actions {
  margin-top: 15px;
  display: flex;
  gap: 10px;
}

/* ========================================
   RESPONSIVE DESIGN
   📱 Mobile & tablet adaptations
======================================== */
@media (max-width: 1400px) {
  .catalogue-sidebar .delivery-info {
    left: 20px;
  }
}

@media (max-width: 1024px) {
  .hero-section {
    gap: var(--spacing-3xl);
  }
  
  .image-column {
    flex: 1;
  }
  
  .logo-link {
    font-size: 28px;
  }
  
  .search-input {
    width: 240px;
  }
}

@media (max-width: 768px) {
  /* Header responsive - Two lines layout */
  .proshop-header-new {
    height: auto;
    padding: var(--spacing-sm) 0;
  }

  .header-container {
    padding: 0 var(--spacing-md);
  }

  /* Hide desktop layout */
  .header-desktop {
    display: none;
  }

  /* Show mobile layout */
  .header-mobile {
    display: block;
  }

  /* First line: SHOP left, MUUN center */
  .header-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    height: 40px;
    margin-bottom: var(--spacing-sm);
  }

  .header-mobile .header-left {
    flex: 0 0 auto;
  }

  .header-mobile .header-center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    flex: 0 0 auto;
  }

  /* Second line: Search, Cart, Log out */
  .header-bottom-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-lg);
  }

  .header-mobile .header-right {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
  }
  
  .header-mobile .search-input {
    width: 105px;
  }

  .search-input {
    width: 100%;
    max-width: 200px;
  }
  
  /* Layout responsive */
  .catalogue-layout {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }
  
  .catalogue-sidebar {
    margin-bottom: var(--spacing-lg);
  }

  .catalogue-sidebar .delivery-info {
    position: static;
    margin-top: 20px;
    width: auto;
    left: auto;
  }

  .catalogue-sidebar .categories-nav {
    margin-bottom: 30px; /* Remet le margin normal sur mobile */
  }
  
  .categories-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 15px;
  }
  
  .products-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 15px;
  }
  
  .pagination-list {
    flex-wrap: wrap;
    justify-content: center;
  }
  
  /* Home page responsive */
  .hero-section {
    flex-direction: column;
    gap: var(--spacing-2xl);
    margin-top: var(--spacing-2xl);
  }
  
  .image-column {
    flex: none;
    order: 1;
  }
  
  .content-column {
    flex: none;
    max-width: none;
    order: 2;
  }
  
  .product-image-container {
    max-width: 320px;
    margin: 0 auto;
  }
  
  .proshop-accueil .welcome-section h1 {
    font-size: 2rem;
  }
  
  /* Buttons responsive */
  .btn-shop,
  .btn-cart,
  .btn-logout {
    padding: 6px 12px;
    font-size: 12px;
  }
  
  .btn-cart svg,
  .btn-logout svg {
    width: 16px;
    height: 16px;
  }
  
  .logo-link {
    font-size: 24px;
    letter-spacing: 2px;
  }
  
  /* Product detail responsive */
  .produit-layout {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }
  
  .produit-image img {
    max-height: 400px;
  }
  
  .produit-title {
    font-size: 1.5rem;
  }
  
  .variations-grid {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }
  
  .similaires-grid {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  }
  
  /* Container responsive */
  .main-container,
  .container {
    padding: 0 var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .search-input {
    width: 180px;
  }
  
  .categories-grid {
    grid-template-columns: 1fr;
  }
  
  .products-grid {
    grid-template-columns: 1fr;
  }
  
  .hero-section {
    gap: var(--spacing-lg);
  }
  
  .btn-shop-main {
    padding: 12px var(--spacing-lg);
    font-size: 14px;
  }
}
