/**
 * Keisove Designer 1.1 - premium stepped UI for PDP.
 * Tokens come from theme: --ink, --ink-2, --ink-3, --ember, --cream, --ash, etc.
 */

/* ── Stage (gallery slot) ────────────────────────────────────────────── */
.ksd-stage{
	position:relative;background:var(--cream,#F4EFE7);
	border:1px solid var(--line-dark,rgba(14,14,16,0.08));border-radius:22px;
	overflow:hidden;aspect-ratio:1/1;max-width:560px;width:100%;
	margin:0 auto 18px;
}
.ksd-stage__inner{width:100%;height:100%}
.ksd-stage__inner > .konvajs-content{width:100% !important;height:100% !important}
.ksd-stage__inner canvas{width:100% !important;height:auto !important;display:block}
.ksd-stage__hint{
	position:absolute;left:50%;bottom:10px;transform:translateX(-50%);
	background:rgba(14,14,16,0.86);color:#fff;
	font-family:var(--font-mono,monospace);font-size:10px;font-weight:700;
	letter-spacing:0.16em;text-transform:uppercase;
	padding:7px 14px;border-radius:8px;pointer-events:none;
}

/* ── Panel + stepped cards ───────────────────────────────────────────── */
.ksd-panel{display:flex;flex-direction:column;gap:14px;margin:18px 0 6px}

.ksd-step{
	background:var(--ink-2,#151517);
	border:1px solid var(--line,rgba(255,255,255,0.08));
	border-radius:18px;padding:18px 18px 16px;
	color:#E7E7EA;
}
.ksd-step--inline{padding:14px 18px}
.ksd-step--price{background:var(--ink-3,#1C1C1F);border-color:var(--line-orange,rgba(255,90,31,0.4))}
.ksd-step__head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.ksd-step__num{
	display:inline-flex;align-items:center;justify-content:center;
	width:30px;height:30px;border-radius:8px;
	background:var(--ember,#FF5A1F);color:#fff;
	font-family:var(--font-display,Oswald,sans-serif);font-weight:700;
	font-size:13px;letter-spacing:0.04em;
	/* cut-corner notch */
	clip-path:polygon(0 0, 100% 0, 100% 70%, 80% 100%, 0 100%);
}
.ksd-step__title{
	margin:0;font-family:var(--font-display,Oswald,sans-serif);
	font-size:17px;line-height:1.1;font-weight:700;letter-spacing:0.005em;
	text-transform:uppercase;color:#fff;
}
.ksd-step__chip{
	margin-left:auto;font-family:var(--font-mono,monospace);font-size:10px;font-weight:700;
	letter-spacing:0.18em;text-transform:uppercase;color:var(--ash,#9A9A9E);
	padding:4px 8px;background:rgba(255,255,255,0.05);border-radius:6px;
}
.ksd-step__hint{margin:0 0 12px;font-size:12px;color:var(--ash,#9A9A9E);line-height:1.5}

/* ── Photo upload ────────────────────────────────────────────────────── */
.ksd-photo{display:flex;flex-direction:column;gap:8px}
.ksd-photo__drop{
	display:flex;align-items:center;gap:14px;
	padding:18px;cursor:pointer;
	background:rgba(255,90,31,0.05);
	border:2px dashed var(--line-orange,rgba(255,90,31,0.4));
	border-radius:14px;
	transition:background .15s,border-color .15s,transform .15s;
}
.ksd-photo__drop:hover{background:rgba(255,90,31,0.08);border-color:var(--ember,#FF5A1F);transform:translateY(-1px)}
.ksd-photo__drop.is-drag{background:rgba(255,90,31,0.14);border-color:var(--ember,#FF5A1F)}
.ksd-photo__drop.is-loading{opacity:0.7;cursor:wait}
.ksd-photo__icon{
	width:48px;height:48px;border-radius:12px;flex-shrink:0;
	background:var(--ember,#FF5A1F);color:#fff;
	display:flex;align-items:center;justify-content:center;
}
.ksd-photo__copy{display:flex;flex-direction:column;gap:2px;line-height:1.3}
.ksd-photo__copy b{font-family:var(--font-display,Oswald,sans-serif);font-size:15px;letter-spacing:0.01em;text-transform:uppercase;color:#fff}
.ksd-photo__copy span{font-size:12px;color:var(--ash,#9A9A9E)}

.ksd-photo__loaded{
	display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center;
	padding:12px;background:rgba(255,255,255,0.04);
	border:1px solid var(--line,rgba(255,255,255,0.08));border-radius:14px;
}
.ksd-photo__loaded[hidden]{display:none}
.ksd-photo__thumb{width:64px;height:64px;object-fit:cover;border-radius:10px;background:#000;border:1px solid var(--line,rgba(255,255,255,0.08))}
.ksd-photo__meta{display:flex;flex-direction:column;gap:2px;min-width:0;overflow:hidden}
.ksd-photo__meta b{font-size:13px;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ksd-photo__meta small{font-size:11px;color:var(--ash,#9A9A9E)}
.ksd-photo__warn{color:#FCAA1A !important}
.ksd-photo__actions{display:flex;flex-direction:column;gap:4px;align-items:flex-end}
.ksd-photo__msg{margin:0;font-size:12px;min-height:14px}

/* Photo modes radios */
.ksd-photo-modes{
	display:flex;flex-direction:column;gap:8px;margin-top:14px;
	background:var(--ink-3,#1C1C1F);
	border:1px solid var(--line,rgba(255,255,255,0.08));
	border-radius:12px;padding:12px;
}
.ksd-photo-modes[hidden]{display:none}
.ksd-radio{display:flex;align-items:flex-start;gap:10px;cursor:pointer;padding:6px;border-radius:8px;transition:background .15s}
.ksd-radio:hover{background:rgba(255,255,255,0.03)}
.ksd-radio input{margin:3px 0 0;accent-color:var(--ember,#FF5A1F)}
.ksd-radio span{display:flex;flex-direction:column;gap:1px;line-height:1.3}
.ksd-radio span b{font-size:13px;color:#fff}
.ksd-radio span small{font-size:11px;color:var(--ash,#9A9A9E)}

/* ── Text upsell ─────────────────────────────────────────────────────── */
.ksd-text-list{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}
.ksd-text-list:empty{display:none}
.ksd-text-item{
	background:var(--ink-3,#1C1C1F);
	border:1px solid var(--line,rgba(255,255,255,0.08));border-radius:12px;
	padding:12px;display:flex;flex-direction:column;gap:10px;
}
.ksd-text-item__head{display:flex;align-items:center;justify-content:space-between}
.ksd-text-item__head b{font-family:var(--font-mono,monospace);font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--ash,#9A9A9E)}
.ksd-text-item__row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:flex-end}

.ksd-input,.ksd-step input[type="text"],.ksd-step select{
	background:var(--ink,#0E0E10);color:#fff;
	border:1px solid var(--line-strong,rgba(255,255,255,0.18));border-radius:10px;
	padding:11px 13px;font-family:var(--font-body,Montserrat,sans-serif);font-size:14px;
	font-weight:600;letter-spacing:0.02em;width:100%;outline:none;
	transition:border-color .15s,box-shadow .15s;
}
.ksd-input:focus,.ksd-step input:focus,.ksd-step select:focus{
	border-color:var(--ember,#FF5A1F);box-shadow:0 0 0 3px rgba(255,90,31,0.18);
}
.ksd-step input[type="color"]{width:42px;height:42px;border:1px solid var(--line-strong,rgba(255,255,255,0.18));background:transparent;cursor:pointer;padding:2px;border-radius:10px}

.ksd-field{display:flex;flex-direction:column;gap:5px}
.ksd-field--narrow{flex:0 0 56px}
.ksd-field__label{font-family:var(--font-mono,monospace);font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--ash,#9A9A9E)}

/* ── Buttons ─────────────────────────────────────────────────────────── */
.ksd-btn{
	background:var(--ember,#FF5A1F);color:#fff;border:0;border-radius:12px;
	padding:12px 18px;font-family:var(--font-mono,monospace);font-size:11px;font-weight:700;
	letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;
	transition:transform .15s,filter .15s;
}
.ksd-btn:hover{transform:translateY(-1px);filter:brightness(1.08)}
.ksd-btn--ghost{
	background:transparent;color:#fff;
	border:1px solid var(--line-strong,rgba(255,255,255,0.18));
}
.ksd-btn--ghost:hover{border-color:var(--ember,#FF5A1F);color:var(--ember,#FF5A1F)}
.ksd-btn-text{
	background:transparent;border:0;color:var(--ash,#9A9A9E);
	font-size:11px;font-weight:600;letter-spacing:0.04em;cursor:pointer;padding:4px 6px;
}
.ksd-btn-text:hover{color:#fff}
.ksd-btn-text--danger:hover{color:#EF4444}

/* ── Background preset grid ──────────────────────────────────────────── */
.ksd-bg-presets{display:grid;grid-template-columns:repeat(9,1fr);gap:6px}
.ksd-bg-preset{
	position:relative;aspect-ratio:1/1;border-radius:10px;cursor:pointer;
	border:2px solid var(--line,rgba(255,255,255,0.12));
	transition:border-color .15s,transform .15s;padding:0;overflow:hidden;
}
.ksd-bg-preset:hover{border-color:var(--ember,#FF5A1F);transform:translateY(-1px)}
.ksd-bg-preset.is-selected{border-color:var(--ember,#FF5A1F);box-shadow:0 0 0 2px rgba(255,90,31,0.3)}
.ksd-bg-preset--transparent{
	background:linear-gradient(45deg,#555 25%,transparent 25%,transparent 75%,#555 75%,#555) 0 0/14px 14px,
	           linear-gradient(45deg,#555 25%,transparent 25%,transparent 75%,#555 75%,#555) 7px 7px/14px 14px,
	           #ccc;
}
.ksd-bg-preset__check{
	position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
	color:#fff;font-weight:900;font-size:18px;text-shadow:0 1px 2px rgba(0,0,0,0.5);
	opacity:0;transition:opacity .15s;
}
.ksd-bg-preset.is-selected .ksd-bg-preset__check{opacity:1}

/* ── Price summary ───────────────────────────────────────────────────── */
.ksd-price{display:flex;flex-direction:column;gap:8px}
.ksd-price__line{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#D7D7DA}
.ksd-price__line b{color:#fff;font-family:var(--font-display,Oswald,sans-serif);font-weight:700}
.ksd-price__extras .ksd-price__line b{color:var(--ember,#FF5A1F)}
.ksd-price__extras:empty{display:none}
.ksd-price__total{
	display:flex;justify-content:space-between;align-items:baseline;
	padding-top:10px;border-top:1px dashed rgba(255,255,255,0.16);
}
.ksd-price__total span{font-family:var(--font-mono,monospace);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ash,#9A9A9E)}
.ksd-price__total b{font-family:var(--font-display,Oswald,sans-serif);font-weight:700;font-size:30px;color:var(--ember,#FF5A1F);letter-spacing:0.005em}

/* ── Theme overrides on designer products ────────────────────────────── */
.ksd-active .gallery__main .gallery__image,
.ksd-active .gallery__case-fallback{display:none !important}
/* Gallery thumbnails MUST stay scrollable */
.ksd-active .gallery__thumbs{display:flex !important}
.ksd-active .gallery__thumb{display:block !important;opacity:0.7;cursor:pointer}
.ksd-active .gallery__thumb.active{opacity:1}

/* Brand-photo overlay shown when a non-designer thumb is clicked */
.ksd-gallery-overlay{
	position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
	background:var(--cream,#F4EFE7);z-index:2;display:block;cursor:zoom-out;
}
.ksd-gallery-overlay[hidden]{display:none !important}
.ksd-gallery-overlay-close{
	position:absolute;top:10px;right:10px;z-index:3;
	background:rgba(14,14,16,0.85);color:#fff;border:0;border-radius:50%;
	width:34px;height:34px;font-size:18px;cursor:pointer;line-height:1;
}
.ksd-gallery-overlay-close[hidden]{display:none}
/* Make sure arrows sit above the overlay so user can keep cycling */
.ksd-active .gallery__arrow{z-index:4 !important}

/* CTA loading state */
.km-cta-main.is-loading,.sticky-cta .cta-add.is-loading{opacity:0.7;cursor:wait;pointer-events:none}

/* ── Mobile ──────────────────────────────────────────────────────────── */
@media (max-width:780px){
	/* NOT sticky on mobile - was overlapping nav/cart drawer when scrolling */
	.ksd-stage{max-width:100%;margin-bottom:14px;position:relative;z-index:0}
	.ksd-bg-presets{grid-template-columns:repeat(6,1fr)}
	.ksd-price__total b{font-size:24px}
	.ksd-photo__loaded{grid-template-columns:54px 1fr;gap:10px}
	.ksd-photo__actions{grid-column:1/-1;flex-direction:row;justify-content:flex-end}
}
