@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@500&family=IBM+Plex+Sans:wght@400;500;600;700&family=Space+Grotesk:wght@500;700&display=swap";:root{color-scheme:light;font-family:var(--font-body);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #ece1d3;--bg-soft: #f7f0e6;--paper: #fffaf1;--ink: #221d1a;--muted: #7a7065;--muted-dark: #5d544a;--line: #d8ccbc;--accent: #c3472f;--accent-dark: #8e2c1f;--shadow: 0 24px 70px rgba(69, 47, 30, .12);--font-display: "Space Grotesk", sans-serif;--font-body: "IBM Plex Sans", sans-serif}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;color:var(--ink);background:radial-gradient(circle at top left,rgba(255,255,255,.72),transparent 26%),radial-gradient(circle at top right,rgba(195,71,47,.08),transparent 28%),linear-gradient(180deg,var(--bg-soft),var(--bg))}button,input,textarea{font:inherit}button{border:none;cursor:pointer;transition:transform .18s ease,background-color .18s ease,border-color .18s ease,color .18s ease,opacity .18s ease}img{display:block;max-width:100%}#root,.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.25rem 1.5rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(180deg,#241e1bf2,#241e1be0),#241e1beb;border-bottom:1px solid rgba(255,255,255,.08)}.brand-lockup,.topbar-actions,.panel-header,.toolbar-actions,.form-actions,.stack-actions{display:flex;align-items:center;gap:.85rem}.brand-badge{display:grid;place-items:center;width:3rem;height:3rem;border-radius:1rem;color:var(--paper);background:linear-gradient(135deg,var(--accent),#e78f55);box-shadow:0 14px 30px #c3472f59}.brand-kicker,.save-pill,.eyebrow,.poster-kicker,.poster-card__label,.row-subtle{letter-spacing:.08em;text-transform:uppercase}.brand-kicker{margin:0 0 .15rem;font-size:.72rem;color:#fff9}.brand-title{margin:0;font-size:1.35rem;color:#fff}.topbar-actions{flex-wrap:wrap;justify-content:flex-end}.save-pill{display:inline-flex;align-items:center;gap:.45rem;padding:.55rem .9rem;border-radius:999px;font-size:.72rem;font-weight:600;color:#ffffffc7;background:#ffffff14}.view-switch{display:inline-flex;padding:.3rem;border-radius:999px;background:#ffffff14}.view-switch button{border:0;padding:.65rem 1rem;border-radius:999px;background:transparent;color:#ffffffb8}.view-switch button:hover{color:#fff}.view-switch .is-active{color:#fff;background:linear-gradient(135deg,var(--accent),#dd7844);box-shadow:0 10px 20px #c3472f47}.page-shell{width:min(1380px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 3rem}.manage-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.95fr);gap:1.35rem;margin-bottom:1.35rem}.panel{border:1px solid rgba(84,63,43,.1);border-radius:1.6rem;padding:1.5rem;background:linear-gradient(180deg,#fffaf1f2,#fcf9f3f2);box-shadow:var(--shadow)}.panel--summary{background:radial-gradient(circle at top right,rgba(195,71,47,.12),transparent 32%),linear-gradient(180deg,#fff7eefa,#fcf8f0fa)}.panel--toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.section-heading{margin-bottom:1.3rem}.section-heading--compact{margin-bottom:1rem}.section-heading h2,.panel-header h2,.toolbar-copy h2{margin:.25rem 0 .5rem;font-family:var(--font-display);font-size:clamp(1.6rem,2vw,2.4rem);line-height:1.02}.section-heading p,.toolbar-copy p{margin:0;max-width:60ch;color:var(--muted)}.eyebrow{font-size:.78rem;font-weight:700;color:var(--accent)}.product-form,.field,.toolbar-copy{display:flex;flex-direction:column}.product-form{gap:1rem}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.field{gap:.45rem}.field span{font-size:.88rem;font-weight:600;color:var(--muted-dark)}.field input,.field textarea{width:100%;border:1px solid rgba(82,68,51,.18);border-radius:1rem;padding:.92rem 1rem;color:var(--ink);background:#ffffffd9;box-shadow:inset 0 1px #fff9}.field textarea{min-height:6.8rem;resize:vertical}.field input:focus,.field textarea:focus{outline:none;border-color:#c3472f73;box-shadow:0 0 0 4px #c3472f1f,inset 0 1px #ffffffb3}.upload-zone{position:relative;display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:center;padding:1rem 1.1rem;border:1px dashed rgba(82,68,51,.24);border-radius:1.2rem;background:#ffffffb3;cursor:pointer}.upload-zone:hover{border-color:#c3472f73;background:#ffffffe6}.upload-zone.has-image{border-style:solid;border-color:#c3472f42;background:linear-gradient(180deg,#fff5f0fa,#fffcf8fa)}.upload-zone input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-zone strong{display:block;margin-bottom:.15rem}.upload-zone p{margin:0;color:var(--muted);font-size:.92rem}.option-check{display:inline-flex;align-items:center;gap:.55rem;margin-top:.2rem;color:var(--muted-dark);font-size:.92rem;font-weight:600}.option-check input{width:1rem;height:1rem;accent-color:var(--accent)}.option-check--compact{margin-top:.75rem;font-size:.88rem}.upload-zone__icon{display:grid;place-items:center;width:2.75rem;height:2.75rem;border-radius:999px;color:var(--accent);background:#c3472f1f}.button{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:2.9rem;padding:.78rem 1.15rem;font-weight:700;border-radius:999px}.form-actions{flex-wrap:wrap}.button:disabled{opacity:.55;cursor:not-allowed}.button--primary{color:#fff;background:linear-gradient(135deg,var(--accent),#dd7844);box-shadow:0 14px 30px #c3472f42}.button--primary:hover:not(:disabled){transform:translateY(-1px)}.button--secondary,.button--ghost{border:1px solid rgba(84,63,43,.14);color:var(--ink);background:#ffffffc7}.button--secondary:hover:not(:disabled),.button--ghost:hover:not(:disabled),.icon-button:hover{border-color:#c3472f52;background:#fff5f0f5}.button--ghost{width:100%}.inline-message{margin:1rem 0 0;padding:.9rem 1rem;border-radius:1rem;color:var(--muted-dark);background:#c3472f17}.stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.stat-card{display:flex;flex-direction:column;gap:.35rem;padding:1rem;border-radius:1.2rem;border:1px solid rgba(84,63,43,.09);background:#ffffffd1}.stat-card--warm{background:linear-gradient(180deg,#fff5eef5,#fffdfbfa)}.stat-card--accent{color:#fff;background:linear-gradient(135deg,#3e2d26,#6f392e 75%,var(--accent))}.stat-card--accent .stat-card__label,.stat-card--accent .stat-card__hint{color:#ffffffc7}.stat-card--ink{color:#fff;background:linear-gradient(135deg,#1c1a18,#40332b)}.stat-card--ink .stat-card__label,.stat-card--ink .stat-card__hint{color:#ffffffad}.stat-card__label{font-size:.72rem;font-weight:700;color:var(--muted)}.stat-card__value{font-family:var(--font-display);font-size:clamp(1.45rem,2vw,2rem);line-height:1}.stat-card__hint{color:var(--muted);font-size:.9rem}.warning-banner,.subtle-banner{display:flex;align-items:flex-start;gap:.75rem;margin-top:1rem;padding:1rem;border-radius:1.15rem}.warning-banner{color:#7e2818;background:#c3472f1f;border:1px solid rgba(195,71,47,.18)}.subtle-banner{color:var(--muted-dark);background:#4c403614}.warning-banner p,.subtle-banner{margin:0}.stack-actions{flex-direction:column;margin-top:1rem}.session-warning{margin-bottom:1rem}.panel-header{justify-content:space-between;margin-bottom:1rem}.table-wrap{overflow-x:auto}.product-table{width:100%;border-collapse:collapse;min-width:760px}.product-table th,.product-table td{padding:.95rem;text-align:left;border-bottom:1px solid rgba(84,63,43,.1);vertical-align:middle}.product-table thead th{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.thumbnail{width:3.25rem;height:3.25rem;object-fit:cover;border-radius:.9rem;border:1px solid rgba(84,63,43,.08)}.thumbnail--empty,.poster-card__placeholder{display:grid;place-items:center;color:#a89b8b;background:linear-gradient(180deg,#f5f1ea,#ece5d8)}.row-brand,.row-price{font-weight:700}.row-price{color:var(--accent-dark)}.row-subtle{margin-top:.2rem;font-size:.7rem;color:var(--muted)}.row-mono{font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:.92rem;color:var(--muted-dark)}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:999px;border:1px solid rgba(84,63,43,.12);color:var(--accent-dark);background:#ffffffd9}.icon-button.is-active{border-color:#c3472f66;color:#fff;background:linear-gradient(135deg,var(--accent),#dd7844)}.row-actions{display:inline-flex;align-items:center;gap:.45rem}.row-is-editing{background:#fff4eef2}.table-empty{padding:2rem;text-align:center;color:var(--muted)}.preview-shell{display:flex;flex-direction:column;gap:1rem}.poster-stage{overflow-x:auto;padding-bottom:.5rem}.export-stage{position:fixed;top:0;left:-10000px;width:1240px;height:1754px;pointer-events:none}.poster-canvas{display:flex;flex-direction:column;width:210mm;min-width:210mm;height:297mm;padding:10mm;border-radius:18px;box-shadow:0 40px 90px #2d231c2e;background:radial-gradient(circle at top right,rgba(195,71,47,.14),transparent 24%),radial-gradient(circle at top left,rgba(255,255,255,.46),transparent 28%),linear-gradient(180deg,#fbf7f0,#f2eadf)}.poster-header{flex-shrink:0;padding:4.2mm 4.5mm 3.8mm;border-radius:4mm;border:.3mm solid rgba(255,255,255,.16);text-align:left;background:linear-gradient(145deg,#172333fa,#122c42f5 68%,#1e364efa)}.poster-kicker{display:block;margin:0 0 1.4mm;font-size:2.55mm;font-weight:700;line-height:1;color:#8bc0f0}.poster-title{margin:0;font-family:var(--font-display);font-size:7.6mm;line-height:.94;text-transform:uppercase;letter-spacing:.01em;color:#fff}.poster-subtitle{margin:1.2mm 0 0;font-size:2.9mm;line-height:1.1;color:#fff5ecd1;font-weight:500}.poster-chip{display:inline-flex;align-items:center;margin-top:2mm;padding:1.25mm 2.8mm;border-radius:999px;font-size:2.45mm;line-height:1;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),#df7b4a)}.poster-products{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:3mm;flex:1;align-content:start;padding:3.8mm 0 3.6mm}.poster-products--empty{display:flex;align-items:center;justify-content:center}.poster-card{display:grid;grid-template-columns:24mm 1fr;min-height:55mm;overflow:hidden;border-radius:4mm;border:.3mm solid rgba(84,63,43,.12);background:#fffffff2;box-shadow:0 1.6mm 4mm #543f2b14}.poster-card__media{position:relative;display:flex;align-items:center;justify-content:center;height:auto;padding:1.8mm;border-right:.25mm solid rgba(84,63,43,.09);background:linear-gradient(180deg,#fffdf9fa,#f4ece0fa)}.poster-card__media img{width:100%;height:auto;aspect-ratio:1 / 1;object-fit:contain}.poster-card__placeholder{width:100%;height:100%;gap:1mm;text-align:center;font-size:2.4mm;line-height:1.1;font-weight:700}.poster-card__badge{position:absolute;top:1mm;right:1mm;padding:.55mm 1.4mm;border-radius:999px;font-size:1.95mm;line-height:1;font-weight:700;color:#fff;background:#c3472ff5}.poster-card__body{display:flex;flex-direction:column;min-width:0;padding:2.2mm}.poster-card__meta,.poster-card__pricing{display:flex;align-items:center;justify-content:flex-start;gap:1.5mm}.poster-card__brand{display:inline-flex;align-items:center;min-height:4.5mm;padding:.3mm 1.4mm;border-radius:999px;font-size:2.2mm;line-height:1;font-weight:700;text-transform:uppercase;color:#174684;background:#e9f1fe}.poster-card__description{margin:1.3mm 0 0;font-size:2.86mm;line-height:1.2;min-height:calc(1.2em * 3);display:-webkit-box;overflow:hidden;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow-wrap:break-word;text-wrap:pretty}.poster-card__pricing{margin-top:auto;padding-top:1.8mm;border-top:.25mm solid rgba(84,63,43,.08);justify-content:space-between;align-items:flex-end}.poster-card__label{display:block;margin-bottom:.45mm;font-size:2.05mm;line-height:1;color:#7f7468;font-weight:700}.poster-card__price{display:block;font-family:var(--font-display);font-size:4.8mm;line-height:1;color:var(--accent)}.poster-card__list{display:flex;flex-direction:column;align-items:flex-end;text-align:right;font-size:2.55mm;line-height:1.05;color:#9d9387}.poster-card__list span:last-child{text-decoration:line-through;font-weight:700}.poster-card__ref{margin:1mm 0 0;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:1.95mm;line-height:1;color:#8c8276}.poster-empty{display:grid;place-items:center;min-height:90mm;width:100%;text-align:center;border:.4mm dashed rgba(84,63,43,.18);border-radius:5mm;color:#6f6458;background:#ffffffbf}.poster-footer{flex-shrink:0;padding:2.4mm 2.8mm 0;text-align:center;border-top:.6mm solid rgba(84,63,43,.18);border-radius:3mm;background:#fffcf699}.poster-footer p{margin:0;font-size:2.25mm;line-height:1.12;color:#796e61}.poster-footer p+p{margin-top:.6mm}.poster-canvas--capture{border-radius:0;box-shadow:none}.poster-canvas--capture .poster-card{height:55mm;min-height:55mm}.poster-canvas--export{width:1240px;min-width:1240px;height:1754px;padding:59px;border-radius:0;box-shadow:none}.poster-canvas--export .poster-header{padding:26px 30px 24px;border-radius:25px;border-width:2px}.poster-canvas--export .poster-kicker{margin-bottom:8px;font-size:15px;line-height:1}.poster-canvas--export .poster-title{font-size:50px;line-height:.95}.poster-canvas--export .poster-subtitle{margin-top:8px;font-size:17px;line-height:1.1}.poster-canvas--export .poster-chip{margin-top:11px;padding:7px 16px;font-size:14px;line-height:1}.poster-canvas--export .poster-products{gap:18px;padding:22px 0 18px}.poster-products--export{grid-auto-rows:1fr}.poster-canvas--export .poster-card{grid-template-columns:146px 1fr;min-height:322px;height:322px;border-radius:20px;border-width:2px;box-shadow:0 8px 26px #543f2b14}.poster-canvas--export .poster-card__media{padding:10px;border-right-width:1px}.poster-canvas--export .poster-card__placeholder{gap:6px;font-size:13px;line-height:1.1}.poster-canvas--export .poster-card__placeholder svg{width:30px;height:30px}.poster-canvas--export .poster-card__badge{top:7px;right:7px;padding:4px 8px;font-size:11px;line-height:1}.poster-canvas--export .poster-card__body{padding:12px}.poster-canvas--export .poster-card__meta,.poster-canvas--export .poster-card__pricing{gap:8px}.poster-canvas--export .poster-card__brand,.poster-canvas--export .poster-card__code{min-height:24px;padding:2px 8px}.poster-canvas--export .poster-card__brand{font-size:12px;line-height:1}.poster-canvas--export .poster-card__description{margin-top:8px;font-size:16px;min-height:calc(1.2em * 3)}.poster-canvas--export .poster-card__pricing{padding-top:9px;border-top-width:1px}.poster-canvas--export .poster-card__label{margin-bottom:2px;font-size:11px;line-height:1}.poster-canvas--export .poster-card__price{font-size:30px}.poster-canvas--export .poster-card__list{font-size:16px;line-height:1.05}.poster-canvas--export .poster-card__ref{margin-top:6px;font-size:10px}.poster-canvas--export .poster-empty{min-height:530px;border-width:2px;border-radius:28px}.poster-canvas--export .poster-footer{padding:14px 18px 0;border-top-width:4px;border-radius:16px}.poster-canvas--export .poster-footer p{font-size:12px;line-height:1.12}.poster-canvas--export .poster-footer p+p{margin-top:4px}.qr-panel{margin-top:1.2rem;padding:1.1rem;border:1px solid rgba(84,63,43,.12);border-radius:1.25rem;background:#ffffffa8}.qr-panel__content{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center}.qr-panel__code,.qr-panel__placeholder{display:grid;place-items:center;width:13rem;min-height:13rem;padding:.9rem;border-radius:1.25rem;background:#fffaf1f2;border:1px solid rgba(84,63,43,.12)}.qr-panel__placeholder{gap:.5rem;color:var(--muted);text-align:center}.qr-panel__meta{display:flex;flex-direction:column;gap:.8rem}.qr-panel__meta p{margin:0;color:var(--muted)}.qr-panel__status,.session-chip,.mobile-status{display:inline-flex;align-items:center;gap:.5rem}.qr-panel__status{font-weight:700;color:var(--ink)}.session-chip{width:fit-content;padding:.55rem .8rem;border-radius:999px;font-size:.82rem;font-weight:700;color:var(--accent-dark);background:#c3472f1f}.qr-panel__actions{display:flex;flex-wrap:wrap;gap:.75rem}.mobile-upload-shell{min-height:100vh;padding:1rem;background:radial-gradient(circle at top left,rgba(255,255,255,.72),transparent 24%),radial-gradient(circle at bottom right,rgba(195,71,47,.12),transparent 30%),linear-gradient(180deg,var(--bg-soft),var(--bg))}.mobile-upload-card{width:min(100%,760px);margin:0 auto;padding:1.25rem;border:1px solid rgba(84,63,43,.12);border-radius:1.5rem;background:#fff9f1f0;box-shadow:var(--shadow)}.mobile-upload-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.mobile-brand-title{color:var(--ink)}.session-chip--mobile{flex-shrink:0}.mobile-upload-copy{margin:1rem 0;color:var(--muted-dark)}.mobile-loading{display:flex;align-items:center;gap:.75rem;padding:1.1rem;border-radius:1rem;background:#ffffffc7}.mobile-banner{margin-top:0;margin-bottom:1rem}.mobile-product-grid{display:grid;gap:.75rem}.mobile-product-tile{display:grid;grid-template-columns:4rem 1fr;gap:.85rem;align-items:center;width:100%;padding:.8rem;text-align:left;border:1px solid rgba(84,63,43,.12);border-radius:1rem;color:var(--ink);background:#ffffffd1}.mobile-product-tile.is-active{border-color:#c3472f61;background:linear-gradient(180deg,#fff5f0fa,#fffcf8fa);box-shadow:0 12px 24px #c3472f24}.mobile-product-tile__thumb{display:grid;place-items:center;width:4rem;height:4rem}.mobile-product-tile__thumb img{width:100%;height:100%;object-fit:cover;border-radius:.9rem}.mobile-product-tile__text{display:flex;flex-direction:column;gap:.2rem}.mobile-product-tile__text strong{font-size:.95rem}.mobile-product-tile__text span{color:var(--muted);font-size:.9rem}.mobile-thumb-empty{width:4rem;height:4rem}.mobile-selected-card{margin-top:1rem;padding:1rem;border-radius:1.15rem;background:#ffffffd1;border:1px solid rgba(84,63,43,.1)}.mobile-selected-card__meta h2{margin:.2rem 0 .35rem;font-family:var(--font-display);font-size:1.45rem}.mobile-selected-card__meta p{margin:0;color:var(--muted)}.mobile-upload-cta{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.65rem;width:100%;margin-top:1rem;padding:1rem 1.1rem;border-radius:999px;color:#fff;font-weight:700;background:linear-gradient(135deg,var(--accent),#dd7844);box-shadow:0 14px 30px #c3472f38;cursor:pointer}.mobile-upload-cta input{position:absolute;inset:0;opacity:0;cursor:pointer}.mobile-status{margin-top:1rem;padding:.95rem 1rem;border-radius:1rem;color:var(--muted-dark);background:#c3472f17}.status-error{margin:0;color:#982c1a;font-weight:600}.spin{animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.manage-layout,.panel--toolbar{grid-template-columns:1fr;flex-direction:column;align-items:stretch}.topbar{position:static;flex-direction:column;align-items:stretch}.topbar-actions{justify-content:space-between}}@media(max-width:720px){.page-shell{width:min(100% - 1rem,1280px);padding-top:1rem}.panel{padding:1.1rem;border-radius:1.25rem}.field-grid,.stat-grid{grid-template-columns:1fr}.form-actions,.toolbar-actions,.panel-header,.brand-lockup,.topbar-actions{flex-direction:column;align-items:stretch}.qr-panel__content,.mobile-upload-header{grid-template-columns:1fr;flex-direction:column}.qr-panel__code,.qr-panel__placeholder,.view-switch{width:100%}.view-switch button{flex:1}}@media print{body{background:#fff}.no-print{display:none!important}.page-shell{width:auto;margin:0;padding:0}.poster-stage{overflow:visible}.poster-canvas{border-radius:0;box-shadow:none}@page{size:A4 portrait;margin:0}}
