/* ═══════════════════════════════════════════════════════════════════════
   Wedding QR Generator — tool-specific styles
   Extends _shared/theme.css design tokens (--primary, --bg-card, etc.)
   ═══════════════════════════════════════════════════════════════════════ *//* ── Widget outer (neutralise .tool-widget card — inner blocks are separate cards) ── */.qr-widget{width:100%;max-width:1040px;margin:24px auto 0;padding:0;box-sizing:border-box;background:none;border:0;box-shadow:none}/* ── Layout: left column (form + templates) + tall preview ── */.qr-layout{display:grid;grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);gap:24px;align-items:start}.qr-left-column{display:flex;flex-direction:column;gap:16px;min-width:0;min-height:0}/* ── Card surfaces (same shadow as contador-boda .wc-form-card) ── */.qr-form-card,.qr-preview-sticky,.qr-template-section,.qr-style-section{box-shadow:0 4px 40px rgba(0, 0, 0, 0.08)}/* ── Sticky preview — height synced to left column via JS ── */.qr-preview-sticky{position:sticky;top:88px;display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px 20px 18px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:18px;min-width:0;min-height:0;box-sizing:border-box;overflow:hidden}.qr-preview-url-field{width:100%;align-self:stretch;margin-top:4px;flex-shrink:0}/* ── Section titles ── */.qr-section-title{font-size:0.95rem;font-weight:700;font-family:'Rubik',sans-serif;color:var(--text-heading);margin:0}.qr-preview-heading{font-size:0.82rem;font-weight:700;font-family:'Rubik',sans-serif;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.07em;margin:0;flex-shrink:0}/* Preview header: title + card-size toggle */.qr-preview-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}.qr-size-toggle{position:relative;display:grid;grid-template-columns:1fr 1fr;flex-shrink:0;max-width:min(100%, 240px);padding:3px;background:var(--bg-section-warm);border:1px solid var(--border-light);border-radius:999px;box-sizing:border-box}.qr-size-toggle-indicator{position:absolute;top:3px;bottom:3px;left:3px;width:calc((100% - 6px) / 2);border-radius:999px;background:var(--primary);box-shadow:0 2px 8px -2px rgba(255, 107, 53, 0.45);transition:transform 0.22s cubic-bezier(0.4, 0, 0.2, 1);pointer-events:none;z-index:0}.qr-size-toggle[data-active="small"] .qr-size-toggle-indicator{transform:translateX(100%)}.qr-size-toggle-option{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:4px 10px;border:none;border-radius:999px;background:transparent;color:var(--text-muted);font-family:'Rubik',sans-serif;font-size:0.68rem;font-weight:600;line-height:1.15;text-align:center;white-space:nowrap;cursor:pointer;transition:color 0.18s}.qr-size-toggle-option:hover:not(.qr-size-toggle-option--active){color:var(--text-heading)}.qr-size-toggle[data-active="large"] .qr-size-toggle-option[data-size="large"],.qr-size-toggle[data-active="small"] .qr-size-toggle-option[data-size="small"]{color:#fff}.qr-size-toggle-option:focus-visible{outline:2px solid var(--primary);outline-offset:2px}/* ── Form card ── */.qr-form-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:18px;padding:16px 16px 14px;min-width:0;flex-shrink:0;display:flex;flex-direction:column;gap:12px}/* ── Form layout — even vertical rhythm between every block ── */#qr-form{display:flex;flex-direction:column;gap:12px}/* ── Name row (two fields side by side) ── */.qr-name-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:0}.qr-name-row .qr-field-group{margin-bottom:0}/* ── Field group ── */.qr-field-group{display:flex;flex-direction:column;gap:5px;margin-bottom:0;position:relative}#qr-form .qr-field-group{padding-bottom:14px}#qr-form .qr-field-group[hidden]{display:none !important}/* ── Label ── */.qr-label{font-size:0.75rem;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;color:var(--text-muted);font-family:'Rubik',sans-serif;display:flex;align-items:center;gap:5px}.qr-label-icon{font-size:0.85rem;line-height:1}/* ── Input ── */.qr-input{padding:9px 14px;border:1px solid var(--border-medium);border-radius:10px;font-size:0.92rem;font-family:Inter,sans-serif;color:var(--text-heading);background:var(--bg-card);transition:border-color 0.2s,box-shadow 0.2s;width:100%;box-sizing:border-box}.qr-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.qr-input::placeholder{color:#b8b8ca}.qr-input[type="date"]::-webkit-calendar-picker-indicator{opacity:0.4;cursor:pointer}/* ── Optional double border (modern-stamp frame on any template) ── */.qr-html-card.qr-html-card--bordered{position:relative;border:1px solid #141414}.qr-html-card.qr-html-card--bordered::before{content:"";position:absolute;pointer-events:none;border:1px solid #141414;inset:18px}.qr-html-card.qr-html-card--bordered.qr-html-card--small::before{inset:14px}/* ── Horizontal cards: text 2/3 (left) + QR 1/3 (right) ── */.qr-html-card--small{display:grid;grid-template-columns:minmax(0, 2fr) minmax(0, 1fr);align-items:center;overflow:hidden;box-sizing:border-box}.qr-html-card--small > .qr-html-card__body{grid-column:1;min-width:0;width:100%;max-width:100%;overflow:hidden;box-sizing:border-box}.qr-html-card--small > .qr-html-card__qr-wrap{grid-column:2;min-width:0;width:100%;max-width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}/* ── Design configuration (left column, below template picker) ── */.qr-style-section{background:var(--bg-card);border:1px solid var(--border-light);border-radius:18px;padding:14px 14px 12px;min-width:0;flex:0 0 auto;display:flex;flex-direction:column;gap:10px;position:relative;z-index:2;overflow:visible}.qr-style-section[hidden]{display:none !important}.qr-style-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.qr-style-controls__font{display:flex;align-items:center;gap:6px;flex:1 1 auto;min-width:0;max-width:min(100%, 200px)}.qr-style-controls__font-label{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-size:0.78rem;font-weight:700;font-family:'Rubik',sans-serif;color:var(--text-muted);letter-spacing:0.04em;margin:0;cursor:default}.qr-select--compact{padding:6px 26px 6px 10px;font-size:0.78rem;line-height:1.25;border-radius:10px;min-width:0;width:100%;background-position:right 8px center;background-size:10px 6px}.qr-style-controls__addons{display:flex;align-items:center;gap:8px;flex-shrink:0;padding-left:10px;border-left:1px solid var(--border-light)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}/* ── Template add-on toolbar (border + seal) ── */.qr-template-options{display:flex;align-items:center;gap:8px;min-height:0}.qr-option-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--border-medium);border-radius:10px;background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:border-color 0.18s,color 0.18s,background 0.18s,box-shadow 0.18s}.qr-option-btn:hover{border-color:var(--primary);color:var(--text-heading)}.qr-option-btn--active{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 2px var(--primary-soft)}.qr-option-btn svg{width:18px;height:18px;display:block;flex-shrink:0}.qr-option-seal-picker{position:relative}.qr-option-seal-picker[hidden]{display:none !important}.qr-option-seal-trigger-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px}.qr-option-seal-trigger-icon svg{width:18px;height:18px;display:block}.qr-option-seal-menu{position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:6px;padding:6px 8px;border:1px solid var(--border-light);border-radius:12px;background:var(--bg-card);box-shadow:0 8px 24px rgba(20, 20, 30, 0.12);opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.15s,visibility 0.15s;z-index:20;white-space:nowrap}.qr-option-seal-picker:hover .qr-option-seal-menu,.qr-option-seal-picker:focus-within .qr-option-seal-menu,.qr-option-seal-picker.qr-option-seal-picker--open .qr-option-seal-menu{opacity:1;visibility:visible;pointer-events:auto}.qr-option-seal-choice{width:32px;height:32px;padding:0;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color 0.15s,color 0.15s,background 0.15s}.qr-option-seal-choice:hover{border-color:var(--border-medium);color:var(--text-heading);background:var(--bg-section-warm)}.qr-option-seal-choice--active{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.qr-option-seal-choice svg{width:16px;height:16px}/* ── Photo icon picker (dropdown, same pattern as seal) ── */.qr-option-photo-picker{position:relative}.qr-option-photo-picker[hidden]{display:none !important}.qr-option-photo-trigger-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px}.qr-option-photo-trigger-icon svg{width:18px;height:18px;display:block}.qr-option-photo-trigger-icon img{width:18px;height:18px;object-fit:contain;display:block;pointer-events:none}.qr-option-photo-menu{position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:6px;padding:6px 8px;border:1px solid var(--border-light);border-radius:12px;background:var(--bg-card);box-shadow:0 8px 24px rgba(20, 20, 30, 0.12);opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.15s,visibility 0.15s;z-index:20;white-space:nowrap}.qr-option-photo-picker:hover .qr-option-photo-menu,.qr-option-photo-picker:focus-within .qr-option-photo-menu,.qr-option-photo-picker.qr-option-photo-picker--open .qr-option-photo-menu{opacity:1;visibility:visible;pointer-events:auto}.qr-option-photo-choice{width:32px;height:32px;padding:4px;border:1px solid transparent;border-radius:8px;background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color 0.15s,background 0.15s}.qr-option-photo-choice:hover{border-color:var(--border-medium);background:var(--bg-section-warm)}.qr-option-photo-choice--active{border-color:var(--primary);background:var(--primary-soft)}.qr-option-photo-choice img{width:20px;height:20px;object-fit:contain;display:block;pointer-events:none}/* ── Char counter ── */.qr-char-count{position:absolute;right:0;bottom:0;font-size:0.73rem;color:var(--text-muted);text-align:right;line-height:1}/* ── Field hint ── */.qr-field-hint{font-size:0.78rem;color:var(--text-muted);margin-top:1px}/* ── Template section (left column, below form) ── */.qr-template-section{background:var(--bg-card);border:1px solid var(--border-light);border-radius:18px;padding:14px 14px 12px;min-width:0;flex:0 0 auto;display:flex;flex-direction:column}/* [DELETED]: Size tabs removed from UI.
.qr-size-tabs { ... }
.qr-size-tab { ... }
*//* [DELETED]: Category filter pills removed from UI.
.qr-category-filters { ... }
.qr-category-filter { ... }
*//* ── Template carousel (both orientations) ── */.qr-template-carousel{display:flex;align-items:center;gap:6px;position:relative;flex:1 1 auto;min-height:0;--qr-carousel-gap:10px;--qr-carousel-full:3/* vertical / large: 3 visible */}.qr-template-carousel--small{--qr-carousel-full:2/* horizontal / small: 2 visible */}.qr-carousel-viewport{min-width:0;flex:1 1 auto;container-type:inline-size;container-name:qr-carousel;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px 0 6px}.qr-carousel-viewport::-webkit-scrollbar{display:none}/* Right-edge fade hints that more designs are scrollable */.qr-template-carousel::after{content:'';position:absolute;top:2px;right:34px;bottom:6px;width:36px;background:linear-gradient(to right, transparent, var(--bg-card));pointer-events:none;transition:opacity 0.2s}.qr-template-carousel.qr-carousel-at-start::before,.qr-template-carousel.qr-carousel-at-end::after{opacity:0}.qr-template-carousel::before{content:'';position:absolute;top:2px;left:34px;bottom:6px;width:36px;background:linear-gradient(to left, transparent, var(--bg-card));pointer-events:none;transition:opacity 0.2s;z-index:1}.qr-carousel-btn{flex:0 0 28px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-light);border-radius:50%;background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:border-color 0.18s,color 0.18s,box-shadow 0.18s;padding:0;z-index:2}.qr-carousel-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary);box-shadow:0 2px 8px -2px rgba(255, 107, 53, 0.18)}.qr-carousel-btn:disabled{opacity:0.35;cursor:default}/* ── HTML template preview / export / thumbnails (all template families) ── */.qr-html-export-stage{position:fixed;left:0;top:0;overflow:visible;opacity:0;pointer-events:none;z-index:-1}.qr-preview-html{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;overflow:hidden;pointer-events:none}.qr-preview-html[hidden]{display:none !important}.qr-preview-html__scale{overflow:hidden;flex-shrink:0}.qr-preview-html__inner{flex-shrink:0}#qr-preview-canvas[hidden]{display:none !important}.qr-size--large .qr-thumb-html{width:84px;height:116px}.qr-size--small .qr-thumb-html{width:116px;height:67px}.qr-thumb-html{overflow:hidden;display:flex;align-items:flex-start;justify-content:center;border-radius:5px;background:#fff;flex-shrink:0}/* [DELETED]: Scaled HTML card previews removed — carousel uses static PNG thumbs. */.qr-thumb-html .qr-thumb-img{display:block;width:100%;height:100%;object-fit:contain;border-radius:5px;background:#fff}.qr-thumb-img:not([src]){background:linear-gradient(135deg, #f8f6f3 0%, #efeae4 100%)}/* ── Template track ── */.qr-template-grid{display:flex;flex-wrap:nowrap;gap:var(--qr-carousel-gap);min-height:0;align-items:start}.qr-template-grid .qr-thumb{flex:0 0 calc(
        (100cqw - var(--qr-carousel-full) * var(--qr-carousel-gap))
        / (var(--qr-carousel-full) + 0.5)
    );scroll-snap-align:start;min-width:0}.qr-thumb[hidden]{display:none !important}/* ── Loading state ── */.qr-grid-loading{flex:1 1 100%;display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 0;color:var(--text-muted);font-size:0.85rem}.qr-grid-spinner{width:24px;height:24px;border:2px solid var(--border-medium);border-top-color:var(--primary);border-radius:50%;animation:qr-spin 0.7s linear infinite}@keyframes qr-spin{to{transform:rotate(360deg)}}/* ── Template thumbnail button ── */.qr-thumb{display:flex;flex-direction:column;align-items:center;gap:5px;padding:5px 5px 7px;border:2px solid transparent;border-radius:10px;background:var(--bg-section-warm);cursor:pointer;transition:border-color 0.18s,box-shadow 0.18s,background 0.18s;position:relative;font-family:Inter,sans-serif}.qr-thumb:hover{border-color:var(--border-medium);background:var(--bg-card)}.qr-thumb--active{border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px var(--primary-soft)}.qr-thumb--active::after{content:'✓';position:absolute;top:4px;right:5px;font-size:0.6rem;font-weight:700;color:#fff;background:var(--primary);width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:14px;text-align:center}/* ── Thumbnail canvas (no template — same box as .qr-thumb-html) ── */.qr-thumb-html .qr-thumb-canvas{display:block;width:100%;height:100%;border-radius:5px}/* Template name label */.qr-thumb-label{font-size:0.65rem;font-weight:600;color:var(--text-muted);text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-thumb--active .qr-thumb-label{color:var(--primary)}/* ── Preview wrap — fills remaining space inside the sticky card ── */.qr-preview-wrap{width:100%;max-width:100%;position:relative;border-radius:10px;overflow:hidden;background:var(--bg-section-warm);border:1px solid var(--border-light);flex:1 1 auto;min-height:0}#qr-preview-canvas{display:block;position:absolute;left:50%;top:50%;transform:translate(-50%, -50%);max-width:calc(100% - 12px);max-height:calc(100% - 12px);width:auto;height:auto;border-radius:6px}/* ── Preview placeholder ── */.qr-preview-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px;background:var(--bg-section-warm);color:var(--text-muted);pointer-events:none;transition:opacity 0.2s}.qr-preview-placeholder.qr-preview-placeholder--hidden{opacity:0;pointer-events:none}.qr-placeholder-text{font-size:0.8rem;text-align:center;max-width:160px;line-height:1.4}/* ── Download button ── */.qr-download-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;font-size:0.92rem;border-radius:50px;flex-shrink:0}.qr-download-btn:disabled{opacity:0.4;cursor:not-allowed;pointer-events:none}.qr-download-hint{font-size:0.75rem;color:var(--text-muted);text-align:center;margin:0;line-height:1.3;flex-shrink:0}.qr-download-hint[hidden]{display:none}/* ── Custom date picker (orange calendar, no clock — matches contador-boda style) ── */.wc-datetime-field{position:relative}.wc-datetime-input-wrap{position:relative}.wc-datetime-display{padding-right:48px;cursor:pointer}.wc-datetime-icon-btn{position:absolute;top:50%;right:12px;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:none;color:var(--primary);cursor:pointer;border-radius:8px;transition:background 0.15s}.wc-datetime-icon-btn:hover{background:var(--primary-soft)}.wc-datetime-popover{position:absolute;top:calc(100% + 8px);left:0;z-index:50;background:#fff;border-radius:16px;box-shadow:0 16px 48px rgba(0, 0, 0, 0.14),0 0 0 1px rgba(0, 0, 0, 0.06);overflow:hidden;min-width:min(100%, 280px)}.wc-datetime-popover-body{display:flex;align-items:stretch}.wc-cal-panel{flex:1 1 260px;padding:20px 18px 16px;min-width:0}.wc-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.wc-cal-month-label{font-size:0.95rem;font-weight:700;color:var(--text-heading);text-transform:capitalize;font-family:'Rubik',sans-serif}.wc-cal-nav{width:32px;height:32px;border:none;background:none;border-radius:50%;font-size:1.4rem;line-height:1;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 0.15s}.wc-cal-nav:hover{background:var(--primary-soft);color:var(--primary)}.wc-cal-weekdays{display:grid;grid-template-columns:repeat(7, 1fr);gap:2px;margin-bottom:8px}.wc-cal-weekday{text-align:center;font-size:11px;font-weight:700;color:var(--text-muted);padding:4px 0;font-family:'Rubik',sans-serif}.wc-cal-grid{display:grid;grid-template-columns:repeat(7, 1fr);gap:2px}.wc-cal-day{aspect-ratio:1;border:none;background:none;border-radius:50%;font-size:0.85rem;font-weight:500;font-family:Inter,sans-serif;color:var(--text-heading);cursor:pointer;transition:background 0.15s,color 0.15s}.wc-cal-day:hover:not(:disabled){background:var(--primary-soft);color:var(--text-heading)}.wc-cal-day--today{box-shadow:inset 0 0 0 1.5px var(--border-medium)}.wc-cal-day--selected{background:var(--primary);color:#fff}.wc-cal-day--selected:hover{background:var(--primary-light);color:var(--text-heading)}.wc-cal-day:disabled{color:#ccc;cursor:default}.wc-cal-day--empty{pointer-events:none}.wc-datetime-popover-footer{display:flex;justify-content:flex-start;gap:8px;padding:10px 16px 14px;border-top:1px solid rgba(0, 0, 0, 0.06)}.wc-datetime-popover-footer[hidden]{display:none !important}.wc-dt-action{border:none;background:none;padding:8px 14px;font-size:0.8rem;font-weight:700;letter-spacing:0.04em;font-family:Inter,sans-serif;color:var(--primary);cursor:pointer;border-radius:8px;transition:background 0.15s}.wc-dt-action:hover{background:var(--primary-soft)}.wc-dt-action--primary{color:var(--primary)}@media (max-width: 580px){.wc-datetime-popover{left:0;right:0;min-width:0}}/* ── Responsive ── */@media (max-width: 900px){.qr-layout{grid-template-columns:1fr;min-height:0;max-height:none}.qr-preview-sticky{position:static;order:-1;max-height:none}.qr-template-carousel{--qr-carousel-full:3}.qr-template-carousel--small{--qr-carousel-full:2}}@media (max-width: 580px){.qr-form-card,.qr-template-section,.qr-style-section{padding:14px 12px}.qr-preview-header{flex-wrap:wrap}.qr-size-toggle{max-width:100%;width:100%}.qr-size-toggle-option{font-size:0.72rem;padding:5px 8px}.qr-name-row{grid-template-columns:1fr}.qr-template-carousel{--qr-carousel-gap:8px;--qr-carousel-full:2}.qr-template-carousel--small{--qr-carousel-full:2}.qr-preview-sticky{padding:14px}}