@import"https://fonts.googleapis.com/css2?family=Cormorant:wght@400;500;600&family=Josefin+Sans:wght@400;500;600;700&display=swap";:root{color-scheme:light;font-family:Josefin Sans,sans-serif;background:#f7f3ee;color:#3d3028;--bg: #f7f3ee;--surface: #fffaf4;--surface-strong: #f2e7da;--text: #3d3028;--muted: #6d5d53;--accent: #a85a3a;--accent-dark: #8f492d;--sage: #3d6b5c;--border: rgba(61, 48, 40, .14);--shadow: 0 20px 45px rgba(61, 48, 40, .12)}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top left,rgba(168,90,58,.08),transparent 30%),radial-gradient(circle at bottom right,rgba(61,107,92,.12),transparent 30%),var(--bg);color:var(--text)}body,button,input,select,textarea{font-family:inherit}img{max-width:100%;display:block}button,input,select{font-size:1rem}button{border:0;cursor:pointer}button:disabled{opacity:.6;cursor:not-allowed}input,select{width:100%;border:1px solid var(--border);border-radius:.95rem;padding:.85rem 1rem;background:#fffdf9;color:var(--text)}input:focus,select:focus{outline:2px solid rgba(61,107,92,.2);border-color:#3d6b5c73}label{display:grid;gap:.45rem;color:var(--muted);font-size:.95rem}h1,h2,h3{font-family:Cormorant,serif;font-weight:600;letter-spacing:.01em;margin:0}p{margin:0;line-height:1.55}.app-shell{min-height:100vh;padding:2rem 1.2rem 3rem}.customer-page,.admin-page{max-width:1240px;margin:0 auto;display:grid;gap:1.5rem}.hero-card,.panel{background:#fffaf4eb;border:1px solid var(--border);border-radius:1.5rem;box-shadow:var(--shadow)}.hero-card{padding:1.9rem 2rem}.hero-card h1{font-size:clamp(2.35rem,4vw,4.2rem);line-height:.95;margin-bottom:.9rem}.hero-card p:last-child{max-width:52rem;color:var(--muted)}.panel{padding:1.35rem 1.4rem}.section-heading{display:flex;justify-content:space-between;gap:1rem;align-items:start;margin-bottom:1rem}.section-heading h2{font-size:2rem}.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;color:var(--sage);margin-bottom:.35rem}.muted-text{color:var(--muted)}.success-text{color:var(--sage)}.error-text{color:#9e3b32}.success-panel{border-color:#3d6b5c47}.checkout-success-panel{position:relative;border-width:2px;border-color:#3d6b5c73;background:radial-gradient(circle at 15% 0%,rgba(61,107,92,.18),transparent 45%),#f6fff9f5;box-shadow:0 24px 44px #20483c33,0 0 0 1px #3d6b5c26;animation:checkout-panel-pop .42s ease-out}.checkout-success-panel h2{color:#1f5747;font-size:clamp(2.1rem,3.2vw,2.7rem);margin-bottom:.35rem}.checkout-success-panel p{color:#244f43}.checkout-order-id{margin:.4rem 0 .5rem;padding:.45rem .7rem;border-radius:.7rem;border:1px solid rgba(61,107,92,.25);background:#ffffffc7;display:inline-block;font-size:.98rem}@keyframes checkout-panel-pop{0%{transform:translateY(6px) scale(.995);opacity:.6}to{transform:translateY(0) scale(1);opacity:1}}.customer-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.82fr);gap:1.5rem;align-items:start}.customer-main,.order-sidebar{display:grid;gap:1.5rem}.upload-dropzone{display:grid;gap:.8rem;border:1.5px dashed rgba(61,107,92,.35);background:linear-gradient(180deg,#3d6b5c0f,#ffffffb8);border-radius:1.2rem;padding:1.25rem;color:var(--text);cursor:pointer}.upload-dropzone input[type=file]{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap}.upload-button{justify-self:start;border-radius:999px;padding:.95rem 1.35rem;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#faf7f2;box-shadow:0 14px 30px #a85a3a3d;font-weight:700}.upload-dropzone:focus-within .upload-button{outline:2px solid rgba(61,107,92,.28);outline-offset:3px}.empty-state{border-radius:1.2rem;border:1px dashed var(--border);padding:1.2rem;color:var(--muted)}.editor-layout{display:grid;gap:1.2rem}.photo-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:.8rem}.photo-chip{display:grid;gap:.55rem;padding:.55rem;text-align:left;border:1px solid var(--border);border-radius:1rem;background:#fffdf9;color:var(--text)}.photo-chip img,.photo-chip canvas{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:.8rem}.photo-chip span{font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-chip.is-active{border-color:#a85a3a80;box-shadow:0 0 0 3px #a85a3a14}.editor-main{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);gap:1.2rem;align-items:start}.canvas-shell{width:100%;border-radius:1.2rem;overflow:hidden;aspect-ratio:1 / 1;background:#efe3d5;border:1px solid rgba(61,48,40,.18)}.canvas-shell canvas{width:100%;height:100%;cursor:grab}.canvas-shell canvas:active{cursor:grabbing}.photo-settings{display:grid;gap:.95rem}.payment-options{display:grid;gap:.85rem}.payment-card{display:grid;gap:.35rem;padding:1rem 1rem 1rem 2.6rem;border-radius:1rem;border:1px solid var(--border);background:#fffdf9;position:relative}.payment-card input{position:absolute;left:1rem;top:1.2rem;width:auto}.payment-card span{color:var(--text);font-weight:600}.payment-card small{color:var(--muted);font-size:.85rem}.payment-card.is-active{border-color:#3d6b5c80;box-shadow:0 0 0 3px #3d6b5c14}.picker-group{display:grid;gap:.5rem;margin-bottom:1rem}.picker-group:last-child{margin-bottom:0}.picker-label{color:var(--muted);font-size:.95rem}.picker-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.65rem}.size-quantity-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem}.size-quantity-card{display:grid;gap:.5rem;padding:.95rem;border-radius:1rem;border:1px solid var(--border);background:#fffdf9}.size-quantity-card span{color:var(--text);font-weight:700}.size-quantity-card small{color:var(--muted);font-size:.85rem}.picker-card{display:grid;gap:.2rem;padding:.85rem .85rem .85rem 2.4rem;border-radius:1rem;border:1px solid var(--border);background:#fffdf9;position:relative;cursor:pointer}.picker-card input{position:absolute;left:.85rem;top:.95rem;width:auto}.picker-card span{color:var(--text);font-weight:600}.picker-card small{color:var(--muted);font-size:.85rem}.picker-card.is-active{border-color:#3d6b5c80;box-shadow:0 0 0 3px #3d6b5c14}.form-grid,.stack-form{display:grid;gap:1rem}.summary-list{display:grid;gap:.8rem;margin-bottom:1rem}.summary-card{display:grid;grid-template-columns:144px minmax(0,1fr);align-items:center;gap:.85rem;padding:.65rem;border-radius:1rem;background:#f2e7da6b}.summary-card>div{min-width:0}.summary-card p{overflow-wrap:anywhere}.summary-card img,.summary-card canvas{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:.8rem}.summary-total{font-size:1.45rem;font-weight:700;color:var(--accent)}.summary-pricing{display:grid;gap:.45rem;padding:.75rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:1rem}.summary-pricing p{display:flex;justify-content:space-between;gap:1rem;margin:0}.primary-button,.secondary-button{border-radius:999px;padding:.95rem 1.35rem;font-weight:700;transition:transform .15s ease,background .15s ease,box-shadow .15s ease}.primary-button{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#faf7f2;box-shadow:0 14px 30px #a85a3a3d}.secondary-button{background:#3d6b5c1a;color:var(--sage);border:1px solid rgba(61,107,92,.2)}.full-width{width:100%}.admin-auth-shell{min-height:calc(100vh - 5rem);display:grid;place-items:center}.admin-auth-panel{width:min(100%,440px)}.admin-hero{display:flex;justify-content:space-between;gap:1rem;align-items:start}.admin-actions{display:flex;gap:.8rem;flex-wrap:wrap}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.2rem}.admin-order-card{display:grid;gap:1rem}.admin-order-header,.order-meta-grid{display:grid;gap:.6rem}.admin-order-header{grid-template-columns:minmax(0,1fr) auto;align-items:start}.order-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-print-button{justify-self:start}.admin-item-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:.75rem}.admin-item-card{background:#f2e7da6b;border-radius:1rem;overflow:hidden}.admin-item-card img{width:100%;aspect-ratio:1 / 1;object-fit:cover}.admin-item-card div{padding:.75rem}@media(max-width:960px){.customer-layout,.editor-main{grid-template-columns:minmax(0,1fr)}}@media(max-width:700px){.app-shell{padding-inline:.85rem}.hero-card,.panel{padding:1.15rem;border-radius:1.2rem}.section-heading,.admin-hero,.admin-order-header,.order-meta-grid{grid-template-columns:minmax(0,1fr)}}
