:root{--border:#e2e8f0;--muted:#64748b;--bg:#f8fafc;--primary:#00f260;--amber:#fbbf24;--link:#0B5ED7;}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:#0f172a;background:#fff}
a{color:inherit;text-decoration:none}
.container{max-width:1600px;margin:0 auto;padding:0 16px}

/* Jersey-style navbar */
.jb-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--border)}
.jb-topbar{height:44px;display:flex;align-items:center;background:var(--amber);color:#0f172a}
.jb-topbar-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px}
.jb-topbar a{font-weight:900;font-size:14px;color:#0f172a}
.jb-promo{font-weight:900;font-size:14px;justify-self:center;white-space:nowrap}
.jb-lang{justify-self:start}
.jb-lang select{height:32px;border-radius:999px;border:1px solid rgba(15,23,42,.15);background:rgba(255,255,255,.6);padding:0 12px;font-weight:800;color:#0f172a;outline:none}
.jb-lang select:disabled{opacity:1}
.jb-toplinks{justify-self:end;display:flex;align-items:center;gap:18px;white-space:nowrap}
.jb-toplinks a:hover{text-decoration:underline}
.jb-main{height:84px;display:flex;align-items:center}
.jb-main-inner{display:flex;align-items:center;gap:18px;width:100%}
.jb-logo{font-weight:900;font-size:22px;letter-spacing:-.2px;white-space:nowrap}
.jb-logo span{color:var(--primary)}
.jb-search{flex:1;display:none}
.jb-search-inner{max-width:640px;position:relative}
.jb-search input{width:100%;height:44px;border-radius:999px;border:1px solid var(--border);padding:0 48px 0 18px;font-size:14px;outline:none;background:#fff;color:#0f172a}
.jb-search .icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#64748b;font-weight:900}
.jb-phone{display:none;align-items:center;gap:10px;color:#0f172a;font-weight:900;white-space:nowrap}
.jb-icons{display:flex;align-items:center;gap:12px;margin-left:auto}
.jb-ico{width:40px;height:40px;border-radius:999px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;color:#0f172a;font-weight:900;border:1px solid #e2e8f0}
.jb-ico:hover{background:#e2e8f0}
.jb-bottom{height:48px;border-top:1px solid var(--border)}
.jb-bottom-inner{height:48px;display:flex;align-items:center;gap:18px;font-weight:900;color:#0f172a}
.jb-bottom-inner a:hover{color:#0f172a}
@media (min-width:768px){.jb-search{display:flex;align-items:center}}
@media (min-width:1024px){.jb-phone{display:flex}}

.badge{display:inline-block;padding:2px 8px;border-radius:999px;background:var(--bg);border:1px solid var(--border);font-size:12px;color:#0f172a}
.section{padding:24px 0}
.h1{font-size:32px;font-weight:900;margin:0}
.h2{font-size:18px;font-weight:900;margin:0 0 14px 0;color:#0f172a}
.sub{color:var(--muted);font-size:13px;margin-top:4px}

.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
@media (min-width:1280px){.grid{grid-template-columns:repeat(5,minmax(0,1fr))}}
@media (max-width:1000px){.grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:640px){.grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.card{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 10px 18px rgba(15,23,42,.06)}
.card:hover{border-color:var(--primary);box-shadow:0 0 20px rgba(0,242,96,.12)}
.card .img{height:190px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-weight:900}
.card img{width:100%;height:190px;object-fit:contain;display:block;background:#f8fafc}
.card .body{padding:12px}
.card .title{font-size:14px;font-weight:900;color:#0f172a;min-height:38px;text-align:center}
.card .price{margin-top:6px;font-weight:900;color:#0f172a}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:999px;padding:10px 16px;font-weight:900;font-size:12px;cursor:pointer}
.btn-primary{background:var(--primary);color:#000}
.btn-outline{background:#fff;border-color:var(--border);color:#0f172a}
.btn-block{width:100%}

/* Shop (left preview / right steps) */
.shop-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:1024px){.shop-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:28px}}
.shop-left{background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 18px rgba(15,23,42,.06);padding:12px}
@media (min-width:1024px){.shop-left{grid-column:span 6 / span 6;position:sticky;top:96px;height:calc(100vh - 7.5rem);overflow:auto}}
.shop-preview{width:100%;min-height:420px;background:#f1f5f9;border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.shop-preview img{width:100%;height:100%;object-fit:contain;display:block}
.shop-preview.media-gallery{flex-direction:column;align-items:stretch;justify-content:flex-start}
.shop-preview.media-gallery .media-main{min-height:420px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.shop-preview.media-gallery .media-main img{width:100%;height:100%;object-fit:contain;display:block;position:relative;z-index:1}
.shop-preview.media-gallery .media-main video{width:100%;height:100%;object-fit:contain;display:block;background:#000;position:relative;z-index:1}
.media-arrow{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:999px;border:0;background:var(--primary);color:#fff;font-weight:900;font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:1;user-select:none;z-index:2}
.media-arrow:hover{opacity:.9}
.media-arrow:focus{outline:2px solid var(--primary);outline-offset:2px}
.media-arrow-prev{left:10px}
.media-arrow-next{right:10px}
@media (max-width:640px){.media-arrow{width:32px;height:32px;font-size:20px}}
.media-thumbs{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;padding:10px;border-top:1px solid var(--border);background:#fff}
@media (max-width:640px){.media-thumbs{grid-template-columns:repeat(4,minmax(0,1fr))}}
.media-thumb{border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;overflow:hidden;padding:0;height:64px;display:flex;align-items:center;justify-content:center}
.media-thumb img{width:100%;height:100%;object-fit:contain;display:block;background:#f8fafc}
.media-thumb.active{border-color:var(--primary)}
.shop-right{display:flex;flex-direction:column;gap:22px}
@media (min-width:1024px){.shop-right{grid-column:span 6 / span 6}}
@media (min-width:1280px){.shop-left{grid-column:span 5 / span 5}.shop-right{grid-column:span 7 / span 7}}

.step-card{border-bottom:1px solid var(--border);padding-bottom:16px}
.step-head{display:flex;align-items:center;gap:12px;margin-bottom:12px;cursor:pointer;user-select:none}
.step-pill{padding:6px 12px;border-radius:6px;background:var(--primary);color:#000;font-weight:900;font-size:12px}
.step-title{font-weight:900;color:#0f172a;font-size:18px}
.step-meta{margin-left:auto;font-size:12px;color:var(--muted);font-style:italic;white-space:nowrap}
.step-meta span{font-weight:900;color:#0f172a;font-style:normal}
.step-meta-sep{opacity:.6;margin:0 6px}
.step-body{display:none}
.step-card.active .step-body{display:block}

.option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
@media (min-width:1280px){.option-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}

/* Step 1 styles wants 4 cards per row on desktop */
@media (min-width:1024px){.option-grid.style-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}

/* Step 8 add-ons wants 4 cards per row on desktop */
.option-grid.addons-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (min-width:1024px){.option-grid.addons-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}

.bag-step{
	display:grid;
	grid-template-columns: 360px 1fr;
	gap:18px;
	align-items:start;
	max-width: 980px;
	margin: 0 auto;
}
.bag-img{
	width:100%;
	height:320px;
	object-fit:contain;
	background:#fff;
	border:1px solid var(--border);
	border-radius:10px;
	display:block;
}
@media (max-width: 900px){
	.bag-step{ grid-template-columns: 1fr; }
	.bag-img{ height:260px; }
}
/* Step 3 wants 4 cards per row */
@media (min-width:1280px){.option-grid.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}}

/* Step 4 wants 5 cards per row */
@media (min-width:1024px){.option-grid.grid-5{grid-template-columns:repeat(5,minmax(0,1fr))}}

/* Step 2 sizes grid tweaks */
.sizes-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (min-width:1024px){.sizes-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (min-width:1280px){.sizes-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
.sizes-grid .option{display:flex;flex-direction:column}
.sizes-grid .option img{height:220px;object-fit:contain;object-position:top center}
.sizes-grid .option .opt-img{height:220px}
.sizes-grid .option .js-size-qty{height:42px}
.sizes-grid .opt-dims{padding:0 12px 10px;font-size:11px;text-align:center;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.custom-dims{padding:6px 12px 0}
.custom-dims-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.custom-dims-item{display:flex;flex-direction:column;align-items:stretch;gap:4px}
.custom-dims-label{font-size:12px;font-weight:900;color:#0f172a;text-align:center;line-height:1}
.custom-dims-row .input{height:34px;padding:6px 10px;border-radius:12px;font-size:13px;text-align:center}
.option{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#fff;cursor:pointer;position:relative;box-shadow:0 10px 18px rgba(15,23,42,.06)}
.option:hover{border-color:var(--primary)}
.option.selected{outline:2px solid var(--primary);outline-offset:0}
.opt-check{position:absolute;left:10px;top:10px;width:26px;height:26px;border-radius:999px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:900;color:#0f172a;opacity:0;transform:scale(.92);transition:opacity .12s ease,transform .12s ease}
.option.selected .opt-check{opacity:1;transform:scale(1)}
.option .opt-img{height:160px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-weight:900}
.option img{width:100%;height:160px;object-fit:contain;display:block;background:#f8fafc}
.option .opt-name{padding:10px 10px 0 10px;font-weight:900;font-size:13px;text-align:center;color:#0f172a}
.option .opt-price{padding:2px 10px 10px;color:#0f172a;font-weight:900;text-align:center;font-size:12px}

/* Step 8 qty bar */
.addon-qty-bar{display:flex;gap:10px;align-items:center;justify-content:center;padding:10px 12px 12px}
.addon-qty-btn{height:38px;padding:0 14px}
.addon-qty-input{max-width:120px;height:38px;text-align:center;display:block}
.option.selected .addon-qty-btn,.option.editing .addon-qty-btn{display:none}
.option.selected .addon-qty-input,.option.editing .addon-qty-input{display:block}
.addon-banner-hint{padding:10px 12px 12px;text-align:center;color:var(--muted);font-weight:900;font-size:12px}

/* Banner panel */
.banner-panel{max-width:980px;margin:16px auto 0 auto;border:1px solid var(--border);border-radius:12px;background:#fff;box-shadow:0 10px 18px rgba(15,23,42,.06);padding:12px}
.tabs{display:flex;gap:8px;margin-bottom:12px}
.tab{border:1px solid var(--border);background:#fff;border-radius:999px;padding:8px 14px;font-weight:900;font-size:12px;cursor:pointer}
.tab.active{border-color:var(--primary);outline:2px solid var(--primary);outline-offset:0}
.banner-form{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:10px}
@media (min-width:768px){.banner-form{grid-template-columns:repeat(2,minmax(0,1fr))}}
.banner-label{font-size:12px;font-weight:900;color:#0f172a;margin-bottom:6px}
.price-table{width:100%;border-collapse:collapse}
.price-table th,.price-table td{border-bottom:1px solid var(--border);padding:10px 8px;font-size:13px}
.price-table thead th{color:#0f172a;font-weight:900}

/* Step 9 table layout */
.table-step{display:grid;grid-template-columns:420px 1fr;gap:18px;align-items:start;max-width:1100px;margin:0 auto}
.table-img{width:100%;height:340px;object-fit:contain;background:#fff;border:1px solid var(--border);border-radius:0;display:block}
.table-right{border-top:1px solid var(--border);padding-top:0}
.table-form{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width:768px){.table-form{grid-template-columns:1fr 1fr}}
@media (max-width:900px){.table-step{grid-template-columns:1fr}.table-img{height:280px}}

/* Step 10 delivery + review */
.delivery-step{max-width:1200px;margin:0 auto}
.delivery-title{font-weight:900;font-size:18px;margin:6px 0 12px 0;color:#0f172a}
.delivery-options{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:12px 0 18px 0}
.delivery-card{width:118px;border:1px solid var(--border);border-radius:16px;background:#fff;box-shadow:0 10px 18px rgba(15,23,42,.06);padding:12px 10px;text-align:center;cursor:pointer}
.delivery-card:hover{border-color:var(--primary)}
.delivery-card.selected{outline:2px solid var(--primary);outline-offset:0}
.delivery-day{font-weight:900;font-size:26px;line-height:1;color:#0f172a}
.delivery-month{font-size:11px;color:var(--muted);margin-top:6px}
.delivery-weekday{font-size:11px;color:var(--muted)}
.delivery-badge{font-size:11px;font-weight:900;margin-top:6px}
.delivery-badge.guaranteed{color:#16a34a}
.delivery-badge.estimated{color:#ef4444}
.delivery-price{font-size:12px;font-weight:900;margin-top:8px;color:#0ea5e9}
.delivery-save{font-size:11px;font-weight:900;margin-top:8px;color:#16a34a}
.delivery-save small{display:block;font-size:10px;color:#16a34a;font-weight:900}

.review-wrap{display:flex;justify-content:center}
.review-card{width:520px;max-width:100%;border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:0 14px 26px rgba(15,23,42,.10);padding:18px}
.review-head{text-align:center;font-size:20px;font-weight:900;color:#0ea5e9;margin-bottom:12px}
.review-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.review-row{display:flex;justify-content:space-between;gap:12px;font-size:13px}
.review-row .label{font-weight:900;color:#0f172a}
.review-row .value{font-weight:900;color:#0f172a;text-align:right}
.review-sub{font-size:12px;color:var(--muted);margin:10px 0 8px 0}

.summary{border:1px solid var(--border);border-radius:12px;background:#fff;box-shadow:0 10px 18px rgba(15,23,42,.06)}
.summary .row{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border-top:1px solid var(--border);font-size:13px}
.summary .row:first-child{border-top:none}
.summary .muted{color:var(--muted)}
.canvas-wrap{border:1px solid var(--border);border-radius:12px;padding:12px;background:#fff;box-shadow:0 10px 18px rgba(15,23,42,.06)}
.canvas-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.input{width:100%;border:1px solid var(--border);border-radius:999px;padding:10px 14px;font-size:14px}
.footer{border-top:1px solid var(--border);padding:18px 0;color:var(--muted);font-size:12px}

/* Step 6 artwork form */
.artwork-card{max-width:980px;margin:0 auto;border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:0 14px 26px rgba(15,23,42,.10);padding:16px}
.artwork-top-tabs{display:flex;gap:16px;justify-content:center;margin:6px 0 16px 0}
.artwork-top-tab{min-width:320px;max-width:100%;height:40px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:900;font-size:13px;color:#0ea5e9}
.artwork-top-tab.active{background:#0ea5e9;border-color:#0ea5e9;color:#fff}
.artwork-pane{max-width:980px;margin:0 auto}
.artwork-head{font-weight:900;font-size:18px;color:#0f172a;margin-bottom:12px}
.artwork-section{margin-bottom:14px}
.artwork-label{font-weight:900;font-size:13px;color:#0f172a;margin-bottom:8px}
.artwork-label-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.artwork-label-row .artwork-label{margin-bottom:0}
.artwork-info{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:999px;border:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:900}
.artwork-multi{position:relative}
.artwork-multi-trigger{display:flex;align-items:center;justify-content:space-between;gap:10px}
.artwork-caret{color:var(--muted);font-weight:900}
.artwork-multi-panel{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:20;border:1px solid var(--border);border-radius:10px;background:#fff;max-height:220px;overflow:auto;padding:8px 0}
.artwork-multi-item{display:flex;gap:8px;align-items:center;padding:8px 10px;font-size:13px}
.artwork-multi-item input{margin:0}
.artwork-multi-item:hover{background:#f8fafc}
.artwork-guide{font-size:12px;font-weight:900;color:#2563eb;text-decoration:none}
.artwork-guide:hover{text-decoration:underline}

.artwork-upload-row{display:flex;align-items:center;gap:0;border:1px solid var(--border);border-radius:999px;overflow:hidden;background:#fff}
.artwork-upload-field{flex:1;height:38px;border:none;background:transparent;padding:0 14px;text-align:left;font-size:13px;color:var(--muted);font-weight:900}
.artwork-upload-browse{height:38px;border:none;background:transparent;padding:0 14px;font-size:12px;color:#0ea5e9;font-weight:900;border-left:1px solid var(--border)}
.artwork-hints{margin-top:10px;font-size:11px;color:#0f172a}
.artwork-hint-line{margin-top:4px}
.artwork-hint-dot{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:999px;border:1px solid var(--border);font-size:10px;color:var(--muted);margin-right:6px}

.artwork-textarea{border-radius:10px;padding:12px 14px;font-size:13px;line-height:1.4;resize:vertical}

/* Design page */
.design-page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:0}
.design-page{display:grid;grid-template-columns:320px 1fr;gap:16px;align-items:start}
@media (max-width:1023px){.design-page{grid-template-columns:1fr}}
.design-tools{border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:0 14px 26px rgba(15,23,42,.10);padding:14px;display:flex;flex-direction:column;gap:10px}
.design-tools-title{font-weight:900;font-size:14px;color:#0f172a;margin-bottom:2px}
.design-tool-label{font-weight:900;font-size:12px;color:#0f172a;margin-bottom:6px}
.design-canvas-wrap{border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:0 14px 26px rgba(15,23,42,.10);padding:14px;display:flex;flex-direction:column;min-height:calc(100vh - 210px)}
.design-canvas-wrap canvas{width:100%;display:block}
.design-canvas-stage{position:relative;min-height:0}
.design-stage-overlay{position:absolute;left:12px;right:12px;top:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;pointer-events:none}
.design-stage-overlay .badge,.design-stage-overlay .sub{pointer-events:none}
.design-pan-x{position:absolute;left:12px;right:56px;bottom:12px;height:18px;z-index:5}
.design-pan-y{position:absolute;top:54px;bottom:56px;right:12px;width:18px;z-index:5;writing-mode:bt-lr;appearance:slider-vertical;-webkit-appearance:slider-vertical}
.artwork-choices{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
@media (min-width:768px){.artwork-choices{grid-template-columns:repeat(3,minmax(0,1fr))}}
.artwork-choice{display:flex;gap:10px;align-items:center;border:1px solid var(--border);border-radius:14px;padding:10px 12px;background:#fff;cursor:pointer}
.artwork-choice input{margin:0}
.artwork-choice span{font-weight:900;font-size:13px;color:#0f172a}
.artwork-files{display:flex;flex-direction:column;gap:8px}
.artwork-file-row{display:flex;justify-content:space-between;align-items:center;gap:12px;border:1px solid var(--border);border-radius:14px;padding:10px 12px}
.artwork-file-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:900;font-size:13px}
