/* Marriage Card Maker v2 — extends base tool styles */

/* ── Gallery ── */
.mc-gallery-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.mc-filters{display:flex;gap:8px;flex-wrap:wrap}
.mc-filter{padding:7px 16px;border:1.5px solid var(--gray-200);border-radius:100px;background:var(--bg-primary);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s}
.mc-filter:hover{border-color:var(--primary-400);color:var(--primary-600)}
.mc-filter.active{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}
.mc-projects-btn{white-space:nowrap}
.mc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.mc-card{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);cursor:pointer;transition:all .2s}
.mc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--primary-400)}
.mc-card__img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;background:var(--bg-tertiary)}
.mc-card__info{padding:10px 12px}
.mc-card__name{font-size:13px;font-weight:600;margin-bottom:2px}
.mc-card__tag{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}
.mc-loading{text-align:center;padding:40px;color:var(--text-tertiary);display:flex;flex-direction:column;align-items:center;gap:12px}

/* ── Modal base ── */
.mc-modal{position:fixed;inset:0;background:rgba(15,23,42,.65);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:16px;animation:mcFade .2s}
.mc-modal.hidden{display:none}
@keyframes mcFade{from{opacity:0}to{opacity:1}}
.mc-modal__card{background:var(--bg-secondary);border-radius:var(--radius-2xl);max-width:460px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);padding:24px;position:relative}
.mc-modal--wide{max-width:780px;padding:0;display:flex;overflow:hidden}
.mc-modal__x{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-tertiary);font-size:20px;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center}
.mc-modal__x:hover{background:var(--gray-200)}
.mc-modal__title{font-size:18px;font-weight:700;margin-bottom:16px}

/* ── Template preview modal ── */
.mc-tpl-preview{flex:0 0 50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;padding:20px}
.mc-tpl-preview img{max-width:100%;max-height:70vh;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.1)}
.mc-tpl-info{flex:1;padding:28px 24px;display:flex;flex-direction:column;justify-content:center;gap:12px}
.mc-tpl-info h3{font-size:20px;font-weight:700;margin:0}
.mc-tpl-desc{font-size:14px;color:var(--text-secondary);line-height:1.5;margin:0}
.mc-tpl-tags{display:flex;flex-wrap:wrap;gap:6px}
.mc-meta-tag{padding:4px 10px;background:var(--bg-tertiary);border-radius:100px;font-size:11px;color:var(--text-secondary)}
.mc-tpl-actions{display:flex;flex-direction:column;gap:8px;margin-top:8px}

/* ── My Projects ── */
.mc-projects-list{display:flex;flex-direction:column;gap:10px;padding:4px 0}
.mc-proj{display:flex;align-items:center;gap:12px;padding:10px;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--gray-100)}
.mc-proj__thumb{width:56px;height:75px;object-fit:cover;border-radius:6px;flex-shrink:0}
.mc-proj__info{flex:1;min-width:0}
.mc-proj__names{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-proj__meta{font-size:11px;color:var(--text-tertiary);margin-top:2px}
.mc-proj__days{font-size:12px;font-weight:500;margin-top:2px}
.mc-proj__edit{flex-shrink:0}
.mc-empty{text-align:center;padding:40px 20px;color:var(--text-tertiary);font-size:14px;line-height:1.8}

/* ── Workspace bar ── */
.mc-workspace-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:10px 14px;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--gray-100)}
.mc-tpl-name{flex:1;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mc-project-badge{font-size:11px;padding:3px 10px;border-radius:100px;font-weight:500}
.mc-badge--ok{background:rgba(34,197,94,.1);color:#16a34a}
.mc-badge--exp{background:rgba(239,68,68,.1);color:#dc2626}

/* ── Form fields ── */
.mc-field{margin-bottom:12px}
.mc-field--dis{opacity:.5;pointer-events:none}
.mc-label{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:3px}
.mc-lock{font-size:12px}
.mc-tag{font-size:9px;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}
.mc-tag--fix{background:var(--gray-100);color:var(--text-tertiary)}
.mc-tag--id{background:rgba(239,68,68,.1);color:#dc2626}
.mc-sep{height:1px;background:var(--gray-100);margin:8px 0}
textarea.mc-input[rows="1"]{resize:none;overflow:hidden;min-height:auto;line-height:1.4;padding:9px 12px}
textarea.mc-input{resize:vertical;min-height:36px;line-height:1.5}
.mc-adj{display:flex;gap:6px;margin-top:4px;align-items:flex-end;flex-wrap:wrap}
.mc-adj label{font-size:10px;color:var(--text-tertiary);display:flex;flex-direction:column;gap:1px}
.mc-adj input[type="number"]{width:52px;padding:3px 4px;border:1px solid var(--gray-200);border-radius:4px;font-size:11px;text-align:center}
.mc-adj input[type="color"]{width:26px;height:26px;border:1.5px solid var(--gray-200);border-radius:4px;cursor:pointer;padding:1px}
.mc-grad-toggle{flex-direction:row !important;align-items:center !important;gap:3px !important;background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;cursor:pointer;font-weight:600;font-size:11px}
.mc-grad-toggle input{width:14px;height:14px;accent-color:var(--primary-500)}
.mc-grad-c2{transition:opacity .15s}
.mc-grad-c2.hidden{opacity:0;pointer-events:none;width:0;overflow:hidden}

/* ── Preview ── */
.mc-preview-wrap{position:relative;background:var(--bg-tertiary);border-radius:var(--radius-lg);overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:300px;border:1px solid var(--gray-100);cursor:pointer}
#cardCanvas{max-width:100%;max-height:65vh}
.mc-watermark{position:absolute;inset:0;pointer-events:none;z-index:2;user-select:none;
    background:repeating-linear-gradient(-45deg,transparent,transparent 100px,rgba(0,0,0,.02) 100px,rgba(0,0,0,.02) 102px)}
.mc-fullscreen-hint{position:absolute;bottom:8px;right:10px;font-size:11px;color:var(--text-tertiary);opacity:.6;pointer-events:none}
.mc-canvas-loading{position:absolute;inset:0;background:rgba(255,255,255,.85);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:5}
.mc-canvas-loading.hidden{display:none}

/* ── Fullscreen preview ── */
.mc-fullscreen{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px}
.mc-fullscreen.hidden{display:none}
.mc-fullscreen__close{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:50%;border:none;background:rgba(255,255,255,.15);color:#fff;font-size:24px;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center}
.mc-fullscreen__close:hover{background:rgba(255,255,255,.25)}
#fullscreenCanvas{max-width:95%;max-height:90vh;border-radius:4px}

/* ── Download modal ── */
.mc-dl-rules{display:flex;flex-direction:column;gap:8px;margin:16px 0}
.mc-dl-rule{font-size:13px;color:var(--text-secondary);padding:6px 10px;background:var(--bg-tertiary);border-radius:6px;line-height:1.5}
.mc-dl-rule--warn{color:#c62828;font-weight:600;background:rgba(239,68,68,.06)}
.mc-dl-cost{font-size:15px;padding:10px;background:var(--bg-tertiary);border-radius:8px;text-align:center;margin-bottom:12px}
.mc-dl-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;margin-bottom:12px}
.mc-dl-check input{accent-color:var(--primary-500);width:18px;height:18px}

/* ── Toast ── */
.mc-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--text-primary);color:#fff;padding:10px 24px;border-radius:100px;font-size:14px;z-index:2000;box-shadow:var(--shadow-lg);opacity:0;transition:all .3s;pointer-events:none}
.mc-toast--show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── Layout ── */
.tool-page__content{display:grid;grid-template-columns:1fr 420px;gap:var(--space-6);align-items:start}
.tool-right-col{display:flex;flex-direction:column;gap:var(--space-5);position:sticky;top:var(--space-4)}

/* ── Responsive ── */
@media(max-width:900px){
    .mc-modal--wide{flex-direction:column;max-height:90vh}
    .mc-tpl-preview{max-height:40vh;flex:none}
    .tool-page__content{grid-template-columns:1fr}
    .tool-right-col{position:static}
}
@media(max-width:600px){
    .mc-grid{grid-template-columns:repeat(2,1fr)}
    .mc-adj{flex-wrap:wrap}
    .mc-gallery-bar{flex-direction:column;align-items:stretch}
    .mc-tpl-info{padding:20px 16px}
}

/* ── Settings Panel v3 ── */
.mc-field-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.mc-settings-btn{width:28px;height:28px;border:1.5px solid var(--gray-200);border-radius:6px;background:var(--bg-primary);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.mc-settings-btn:hover{border-color:var(--primary-400);background:rgba(79,70,229,.05)}
.mc-settings-btn--active{border-color:var(--primary-500);background:rgba(79,70,229,.1)}
.mc-settings{background:var(--bg-tertiary);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:10px;margin-top:6px;margin-bottom:4px;animation:mcSlide .2s ease}
.mc-settings.hidden{display:none}
@keyframes mcSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.mc-set-group{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--gray-100)}
.mc-set-group:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.mc-set-title{font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:5px}
.mc-set-row{display:flex;gap:6px;align-items:flex-end;flex-wrap:wrap}
.mc-set-row>label{font-size:10px;color:var(--text-tertiary);display:flex;flex-direction:column;gap:1px}
.mc-set-row input[type="number"]{width:54px;padding:4px 3px;border:1px solid var(--gray-200);border-radius:4px;font-size:11px;text-align:center;background:var(--bg-primary)}
.mc-set-row input[type="color"]{width:28px;height:28px;border:1.5px solid var(--gray-200);border-radius:4px;cursor:pointer;padding:1px;background:var(--bg-primary)}
.mc-set-row input[type="range"]{width:70px;accent-color:var(--primary-500)}
.mc-range-val{font-size:9px;color:var(--text-tertiary);min-width:28px;text-align:right}

/* Nudge buttons (PixelLab style) */
.mc-nudge-label{display:flex !important;flex-direction:row !important;align-items:center !important;gap:2px !important;font-size:10px;color:var(--text-tertiary)}
.mc-nudge{width:22px;height:22px;border:1px solid var(--gray-200);border-radius:4px;background:var(--bg-primary);cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .1s}
.mc-nudge:hover{background:var(--primary-50,rgba(79,70,229,.08));border-color:var(--primary-400)}
.mc-nudge:active{background:var(--primary-100,rgba(79,70,229,.15))}
.mc-nudge-label input[type="number"]{width:48px}

/* Style buttons (B I U) */
.mc-style-btn{width:28px;height:28px;border:1.5px solid var(--gray-200);border-radius:4px;background:var(--bg-primary);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .12s;color:var(--text-secondary)}
.mc-style-btn:hover{border-color:var(--primary-400)}
.mc-style-btn.mc-active{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}

/* Align buttons */
.mc-align-group{display:flex;gap:0;border:1.5px solid var(--gray-200);border-radius:4px;overflow:hidden}
.mc-align-btn{width:26px;height:26px;border:none;border-right:1px solid var(--gray-200);background:var(--bg-primary);cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .12s}
.mc-align-btn:last-child{border-right:none}
.mc-align-btn:hover{background:rgba(79,70,229,.05)}
.mc-align-btn.mc-active{background:var(--primary-500);color:#fff}

/* Gradient toggle inline */
.mc-grad-toggle{flex-direction:row !important;align-items:center !important;gap:3px !important;font-size:10px;cursor:pointer;white-space:nowrap}
.mc-grad-toggle input[type="checkbox"]{width:14px;height:14px;accent-color:var(--primary-500);cursor:pointer}
.mc-grad-c2{transition:all .15s}
.mc-grad-c2.hidden{opacity:0;pointer-events:none;width:0;overflow:hidden;padding:0;margin:0}

/* ── Color picker bar (PixelLab style) ── */
.mc-colorbar{display:flex;align-items:center;gap:6px;margin-top:4px;padding:4px 8px;background:var(--bg-tertiary);border-radius:6px}
.mc-colorbar-hint{font-size:10px;color:var(--text-tertiary);flex:1;font-weight:500}
.mc-cpick{width:28px;height:28px;border:1.5px solid var(--gray-200);border-radius:6px;cursor:pointer;padding:1px;background:none;flex-shrink:0}
.mc-cpick:hover{border-color:var(--primary-400)}
.mc-cclear{width:24px;height:24px;border:1px solid var(--gray-200);border-radius:6px;background:var(--bg-primary);cursor:pointer;font-size:12px;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}
.mc-cclear:hover{background:rgba(239,68,68,.1);color:#dc2626;border-color:#dc2626}

/* Color range tags */
.mc-color-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:3px}
.mc-ctag{display:inline-flex;align-items:center;gap:3px;padding:2px 6px 2px 4px;background:var(--bg-primary);border:1px solid var(--gray-100);border-radius:4px;font-size:11px}
.mc-ctag-text{font-weight:500;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mc-ctag-x{width:14px;height:14px;border:none;background:none;cursor:pointer;font-size:12px;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;padding:0;border-radius:2px}
.mc-ctag-x:hover{background:rgba(239,68,68,.15);color:#dc2626}