/* =====================================================================
 * Namaste Click & Collect - menu front
 * ===================================================================== */

:root {
	--ccn-accent: #b8341f;
	--ccn-accent-dark: #8d2715;
	--ccn-accent-soft: #fbeae7;
	--ccn-text: #1a1a1a;
	--ccn-muted: #6b6b6b;
	--ccn-border: #ececec;
	--ccn-bg: #ffffff;
	--ccn-bg-alt: #fafafa;
	--ccn-success: #2b7a3a;
	--ccn-success-bg: #e6f4ea;
	--ccn-warning-bg: #fff4d5;
	--ccn-radius: 12px;
	--ccn-radius-sm: 8px;
	--ccn-shadow: 0 1px 2px rgba(0,0,0,.04);
	--ccn-shadow-hover: 0 4px 14px rgba(0,0,0,.08);
	--ccn-shadow-modal: 0 20px 50px rgba(0,0,0,.25);
}

.ccn-menu {
	font-family: inherit;
	color: var(--ccn-text);
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 1rem 6rem;
	line-height: 1.5;
}

.ccn-hero {
	display: flex;
	gap: 1.25rem;
	align-items: center;
	padding: 1.5rem 0 1rem;
	border-bottom: 1px solid var(--ccn-border);
}
.ccn-hero-logo img { width: 84px; height: 84px; object-fit: contain; border-radius: var(--ccn-radius-sm); }
.ccn-hero-body { flex: 1; min-width: 0; }
.ccn-hero-title { font-size: 1.75rem; font-weight: 700; margin: 0 0 .4rem; letter-spacing: -.01em; line-height: 1.1; }
.ccn-hero-sub { margin: 0 0 .5rem; display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.ccn-hero-pill { display: inline-flex; align-items: center; gap: .4rem; font-size: .85rem; font-weight: 600; padding: .25rem .65rem; border-radius: 999px; }
.ccn-hero-pill.is-open { background: var(--ccn-success-bg); color: var(--ccn-success); }
.ccn-hero-pill.is-open::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--ccn-success); }
.ccn-hero-pill.is-closed { background: var(--ccn-accent-soft); color: var(--ccn-accent-dark); }
.ccn-hero-pill.is-closed::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--ccn-accent); }
.ccn-hero-next { color: var(--ccn-muted); font-size: .85rem; }
.ccn-hero-meta { margin: 0; color: var(--ccn-muted); font-size: .88rem; display: flex; flex-wrap: wrap; gap: .75rem 1.25rem; }
.ccn-hero-paused { margin: .5rem 0 0; background: var(--ccn-warning-bg); padding: .5rem .75rem; border-radius: var(--ccn-radius-sm); font-size: .9rem; }

/* === NAV categories : sticky avec fallback fixed === */
.ccn-cat-nav {
	position: sticky;
	top: 0;
	z-index: 30;
	background: var(--ccn-bg);
	border-bottom: 1px solid var(--ccn-border);
	margin: 0 -1rem;
	padding: 0 1rem;
	overflow-x: auto !important;
	overflow-y: hidden !important;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	box-sizing: border-box;
	max-width: 100%;
}
.ccn-cat-nav ul { overflow-x: visible !important; }
.ccn-cat-nav::-webkit-scrollbar { display: none; }
.ccn-cat-nav ul {
	display: flex;
	gap: .25rem;
	list-style: none;
	margin: 0;
	padding: .6rem 0;
	white-space: nowrap;
}
.ccn-cat-nav a {
	color: var(--ccn-muted);
	text-decoration: none;
	font-weight: 500;
	font-size: .92rem;
	padding: .45rem .75rem;
	border-radius: 999px;
	transition: background .15s, color .15s;
}
.ccn-cat-nav a:hover { background: var(--ccn-bg-alt); color: var(--ccn-text); }
.ccn-cat-nav a.is-active { background: var(--ccn-text); color: #fff; }

/* Quand stuck par le JS : on l'epingle en haut viewport, largeur viewport clampee */
.ccn-cat-nav.is-stuck {
	position: fixed !important;
	left: 0;
	right: 0;
	width: 100vw;
	max-width: 100vw;
	margin: 0;
	padding: 0;
	z-index: 100;
	box-shadow: 0 2px 8px rgba(0,0,0,.08);
	overflow-x: auto;
	box-sizing: border-box;
}
.ccn-cat-nav.is-stuck ul {
	max-width: 1100px;
	margin: 0 auto;
	padding: .6rem 1rem;
	box-sizing: border-box;
}
.ccn-cat-nav-placeholder { display: none; }

/* === Categories & cards === */
.ccn-category { margin: 2.5rem 0 1rem; scroll-margin-top: 80px; }
.ccn-category-title {
	display: flex; align-items: center; gap: .6rem;
	font-size: 1.3rem; font-weight: 700;
	letter-spacing: -.01em;
	margin: 0 0 1rem; padding: 0; border: none;
}
.ccn-category-icon {
	display: inline-flex;
	width: 32px; height: 32px;
	background: var(--ccn-accent-soft);
	color: var(--ccn-accent);
	border-radius: 50%;
	align-items: center; justify-content: center;
	flex-shrink: 0;
}
.ccn-category-icon svg { width: 18px; height: 18px; }

.ccn-products {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: .85rem;
}
.ccn-product {
	display: flex; gap: .9rem;
	background: var(--ccn-bg);
	border: 1px solid var(--ccn-border);
	border-radius: var(--ccn-radius);
	padding: .85rem;
	cursor: pointer;
	transition: box-shadow .15s, transform .05s;
	outline: none;
}
.ccn-product:hover,
.ccn-product:focus { box-shadow: var(--ccn-shadow-hover); }
.ccn-product:focus { border-color: var(--ccn-accent); }
.ccn-product:active { transform: scale(.995); }
.ccn-product-thumb {
	flex: 0 0 92px;
	width: 92px; height: 92px;
	border-radius: var(--ccn-radius-sm);
	overflow: hidden;
	background: var(--ccn-bg-alt);
}
.ccn-product-thumb img {
	width: 100%; height: 100%;
	object-fit: cover; display: block;
}
.ccn-product-ico {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	background: linear-gradient(135deg, var(--ccn-accent-soft), #fff);
	color: var(--ccn-accent);
}
.ccn-product-ico svg { width: 36px; height: 36px; }
.ccn-product-body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.ccn-product-name { margin: 0 0 .2rem; font-size: .98rem; font-weight: 600; line-height: 1.3; }
.ccn-product-desc {
	margin: 0 0 .5rem;
	font-size: .82rem;
	color: var(--ccn-muted);
	flex: 1;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.ccn-product-meta { display: flex; justify-content: space-between; align-items: center; margin-top: auto; }
.ccn-price { font-weight: 700; color: var(--ccn-text); font-size: .95rem; }
.ccn-price .amount, .ccn-price ins { text-decoration: none; }
.ccn-add {
	background: var(--ccn-text) !important;
	color: #fff !important;
	border: none;
	border-radius: 50%;
	width: 32px; height: 32px;
	min-width: 32px;
	display: inline-flex; align-items: center; justify-content: center;
	cursor: pointer;
	padding: 0;
	transition: background .15s, transform .1s;
	flex-shrink: 0;
	font-size: 1rem;
	line-height: 1;
}
.ccn-add:hover { background: var(--ccn-accent) !important; }
.ccn-add:active { transform: scale(.92); }
.ccn-add[disabled] { opacity: .5; cursor: wait; }

.ccn-menu.is-closed .ccn-products { opacity: .55; pointer-events: none; }

@media (max-width: 600px) {
	.ccn-menu { padding: 0 .75rem 6rem; }
	.ccn-hero { flex-direction: row; align-items: flex-start; padding: 1rem 0 .75rem; }
	.ccn-hero-logo img { width: 56px; height: 56px; }
	.ccn-hero-title { font-size: 1.3rem; }
	.ccn-hero-meta { font-size: .8rem; gap: .4rem .8rem; }
	.ccn-products { grid-template-columns: 1fr; }
	.ccn-product-thumb { flex: 0 0 72px; width: 72px; height: 72px; }
}

/* === MODALE PRODUIT === */
.ccn-modal { position: fixed; inset: 0; z-index: 9999; display: none; align-items: center; justify-content: center; }
.ccn-modal.is-open { display: flex; }
html.ccn-modal-lock { overflow: hidden; }
.ccn-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.5); }
.ccn-modal-panel {
	position: relative;
	background: #fff;
	border-radius: var(--ccn-radius);
	width: min(520px, calc(100vw - 2rem));
	max-height: calc(100vh - 2rem);
	overflow: auto;
	box-shadow: var(--ccn-shadow-modal);
}
.ccn-modal-close {
	position: absolute; top: .5rem; right: .5rem;
	width: 36px; height: 36px; border: none;
	background: rgba(255,255,255,.9); color: var(--ccn-text);
	border-radius: 50%; font-size: 1.5rem; line-height: 1;
	cursor: pointer; z-index: 2;
	box-shadow: var(--ccn-shadow);
}
.ccn-modal-close:hover { background: #fff; }
.ccn-modal-loading { padding: 3rem; text-align: center; color: var(--ccn-muted); }
.ccn-modal-hero { width: 100%; aspect-ratio: 16 / 9; overflow: hidden; background: var(--ccn-bg-alt); }
.ccn-modal-hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ccn-modal-content { padding: 1.25rem; }
.ccn-modal-title { margin: 0 0 .25rem; font-size: 1.35rem; font-weight: 700; }
.ccn-modal-price { color: var(--ccn-accent); font-weight: 700; margin: 0 0 .75rem; }
.ccn-modal-desc { color: var(--ccn-muted); font-size: .93rem; margin: 0 0 1rem; }
.ccn-modal-note-label { display: block; font-size: .85rem; font-weight: 600; margin: .5rem 0 .25rem; }
.ccn-modal-note {
	width: 100%; padding: .5rem .6rem;
	border: 1px solid var(--ccn-border);
	border-radius: var(--ccn-radius-sm);
	font-family: inherit; font-size: .9rem;
	resize: vertical;
	box-sizing: border-box;
}
.ccn-modal-note:focus { outline: 2px solid var(--ccn-accent); outline-offset: 1px; border-color: transparent; }
.ccn-modal-foot { display: flex; gap: .75rem; align-items: center; margin-top: 1rem; }
.ccn-qty {
	display: inline-flex; align-items: center;
	border: 1px solid var(--ccn-border);
	border-radius: 999px;
	overflow: hidden;
	height: 44px;
}
.ccn-qty-btn { background: none; border: none; width: 40px; height: 44px; font-size: 1.2rem; cursor: pointer; color: var(--ccn-text); }
.ccn-qty-btn:hover { background: var(--ccn-bg-alt); }
.ccn-qty-val { min-width: 24px; text-align: center; font-weight: 600; }
.ccn-modal-add {
	flex: 1; height: 44px;
	background: var(--ccn-text) !important;
	color: #fff !important;
	border: none; border-radius: 999px;
	font-weight: 600; font-size: .95rem;
	display: inline-flex; align-items: center; justify-content: space-between;
	padding: 0 1.25rem;
	cursor: pointer;
	transition: background .15s;
}
.ccn-modal-add:hover { background: var(--ccn-accent) !important; }
.ccn-modal-add[disabled] { opacity: .7; cursor: wait; }
.ccn-modal-add-total { font-weight: 700; }

/* === PANIER FLOTTANT === */
.ccn-fc {
	position: fixed;
	left: 50%;
	bottom: 1rem;
	transform: translateX(-50%);
	z-index: 40;
	transition: opacity .2s, transform .2s;
	max-width: calc(100vw - 2rem);
}
.ccn-fc.is-empty { opacity: 0; pointer-events: none; transform: translate(-50%, 2rem); }
.ccn-fc-btn {
	display: inline-flex; align-items: center; gap: .75rem;
	background: var(--ccn-text);
	color: #fff !important;
	padding: .7rem 1rem .7rem .85rem;
	border-radius: 999px;
	box-shadow: 0 4px 16px rgba(0,0,0,.22);
	text-decoration: none;
	font-size: .95rem;
	font-weight: 600;
	transition: background .15s, transform .1s;
}
.ccn-fc-btn:hover { background: var(--ccn-accent); transform: translateY(-1px); }
.ccn-fc-icon svg { width: 22px; height: 22px; display: block; }
.ccn-fc-text { display: inline-flex; flex-direction: column; line-height: 1.15; }
.ccn-fc-count { font-size: .8rem; opacity: .85; font-weight: 500; }
.ccn-fc-total { font-weight: 700; }
.ccn-fc-cta { padding-left: .75rem; border-left: 1px solid rgba(255,255,255,.25); margin-left: .25rem; }

@media (max-width: 600px) {
	.ccn-fc { left: 1rem; right: 1rem; bottom: 1rem; transform: none; max-width: none; }
	.ccn-fc.is-empty { transform: translateY(2rem); }
	.ccn-fc-btn { width: 100%; justify-content: center; }
}

/* === SLOT SELECTOR === */
.ccn-slot-selector {
	background: var(--ccn-bg-alt);
	padding: 1rem 1.25rem;
	border-radius: var(--ccn-radius);
	margin: 1.5rem 0;
	border: 1px solid var(--ccn-border);
}
.ccn-slot-selector h3 { margin: 0 0 .75rem; font-size: 1.1rem; }
.ccn-slot-selector p { margin: 0 0 .75rem; }
.ccn-slot-selector label { display: block; font-size: .85rem; font-weight: 600; margin-bottom: .3rem; color: var(--ccn-text); }
.ccn-slot-selector select,
.ccn-slot-selector textarea {
	width: 100%;
	padding: .6rem .75rem;
	border: 1px solid var(--ccn-border);
	border-radius: var(--ccn-radius-sm);
	font-family: inherit;
	font-size: .95rem;
	background: #fff;
	box-sizing: border-box;
}
