/* ═══════════════════════════════════════
   Marriage Biodata Maker — Tools CSC
   ═══════════════════════════════════════ */

/* ══ SHARED STYLES (gallery, modal, projects, download, toast) ══ */

/* ── 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 ── */
.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}

/* ── 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)}

/* ══ BIODATA-SPECIFIC STYLES ══ */

/* ── Workspace bar (back button + template name + language + projects) ── */
.bd-workspace-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:10px 16px;background:var(--bg-secondary);border-radius:10px;border:1px solid var(--border)}
.bd-workspace-bar .bd-tpl-name{flex:1;font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bd-workspace-bar__right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.bd-label{font-size:11px;font-weight:600;color:var(--text-tertiary);display:block;margin-bottom:2px}

/* ── Language select ── */
.bd-lang-select{padding:5px 8px;border:1px solid var(--border);border-radius:6px;font-size:12px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer}
.bd-lang-select:focus{border-color:var(--primary-400);outline:none}

/* ── Main layout (form + preview) ── */
.bd-main{display:flex;gap:20px;align-items:flex-start}
.bd-form-panel{flex:1;min-width:0;max-height:calc(100vh - 180px);overflow-y:auto;padding-right:4px}
.bd-preview-panel{flex:1;position:sticky;top:80px;min-width:280px}

/* ── Preview wrapper ── */
.bd-preview-wrap{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--bg-tertiary);cursor:pointer}
.bd-preview-wrap canvas{width:100%;display:block}
.bd-wm-overlay{position:absolute;inset:0;pointer-events:none}
.bd-fullscreen-hint{position:absolute;bottom:8px;right:8px;font-size:10px;color:var(--text-tertiary);background:rgba(255,255,255,.8);padding:2px 8px;border-radius:4px}
.bd-canvas-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-tertiary)}

/* ── Fullscreen ── */
.bd-fullscreen{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center}
.bd-fullscreen canvas{max-width:95vw;max-height:95vh;border-radius:8px}
.bd-fullscreen__close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:24px;cursor:pointer}

/* ── Section cards ── */
.bd-section{margin-bottom:14px;padding:14px;background:var(--bg-secondary);border-radius:10px;border:1px solid var(--border)}
.bd-section-title{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}

/* ── God photo section ── */
.bd-god-section{display:flex;flex-direction:column;gap:10px}
.bd-god-row{display:flex;align-items:center;gap:12px}
.bd-god-photo{width:60px;height:60px;border-radius:8px;overflow:hidden;border:2px solid var(--border);background:#fff;cursor:pointer;padding:2px;flex-shrink:0}
.bd-god-photo img{width:100%;height:100%;object-fit:contain}
.bd-god-info{flex:1;display:flex;flex-direction:column;gap:4px}
.bd-god-name{font-size:13px;font-weight:600;padding:6px 8px}
.bd-god-actions{display:flex;gap:10px}
.bd-link{background:none;border:none;font-size:11px;color:var(--primary-600);cursor:pointer;padding:0;font-weight:600;text-decoration:underline}
.bd-link:hover{color:var(--primary-700)}
.bd-link--danger{color:var(--error)}
.bd-link--danger:hover{color:#b91c1c}

/* ── Photo area ── */
.bd-photo-area{display:flex;align-items:center;gap:12px;margin-top:6px}
.bd-photo-preview{width:70px;height:90px;border:2px dashed var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg-tertiary);flex-shrink:0}
.bd-photo-placeholder{font-size:24px;opacity:.4}
.bd-hint{font-size:10px;color:var(--text-tertiary);margin-top:4px}

/* ── QR toggle ── */
.bd-qr-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px}
.bd-qr-fields{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.bd-switch{position:relative;width:36px;height:20px;display:inline-block}
.bd-switch input{opacity:0;width:0;height:0}
.bd-slider{position:absolute;inset:0;background:var(--gray-200);border-radius:20px;transition:.2s;cursor:pointer}
.bd-slider::before{content:'';position:absolute;width:16px;height:16px;left:2px;top:2px;background:#fff;border-radius:50%;transition:.2s}
.bd-switch input:checked+.bd-slider{background:var(--primary-500)}
.bd-switch input:checked+.bd-slider::before{transform:translateX(16px)}

/* ── Form fields ── */
.bd-row{margin-bottom:8px}
.bd-input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}
.bd-input:focus{border-color:var(--primary-400);outline:none;box-shadow:0 0 0 2px rgba(99,102,241,.12)}
.bd-input--sm{padding:5px 8px;font-size:12px}
.bd-textarea{resize:vertical;min-height:36px}
.bd-select{cursor:pointer}

/* ── Field cards with reorder buttons ── */
.bd-field{margin-bottom:6px;padding:6px 10px;border-radius:6px;background:var(--bg-primary);border:1px solid var(--gray-200);transition:border-color .15s}
.bd-field:hover{border-color:var(--primary-400)}
.bd-field--locked{opacity:.8}
.bd-field-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.bd-field-label{font-size:11px;font-weight:600;color:var(--text-secondary)}
.bd-field-actions{display:flex;gap:3px;align-items:center}
.bd-move-btn{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-tertiary);transition:all .1s}
.bd-move-btn:hover:not(:disabled){border-color:var(--primary-400);color:var(--primary-600)}
.bd-move-btn:disabled{opacity:.3;cursor:not-allowed}
.bd-del-btn{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;transition:all .1s}
.bd-del-btn:hover{border-color:#dc2626;background:rgba(239,68,68,.06)}

/* ── Add field button ── */
.bd-add-field-btn{width:100%;margin-top:6px;padding:6px;border:2px dashed var(--gray-200);border-radius:6px;background:transparent;color:var(--text-tertiary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.bd-add-field-btn:hover{border-color:var(--primary-400);color:var(--primary-600);background:rgba(79,70,229,.02)}

/* ── God grid in modal ── */
.bd-god-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-height:70vh;overflow-y:auto;padding:8px 0}
.bd-god-option{width:80px;height:80px;border:2px solid var(--gray-200);border-radius:10px;overflow:hidden;cursor:pointer;padding:4px;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s}
.bd-god-option:hover{border-color:var(--primary-400);transform:scale(1.05)}
.bd-god-option img{width:90%;height:90%;object-fit:contain}

/* ── Pricing ── */
.bd-pricing{text-align:center;font-size:11px;color:var(--text-tertiary);margin-top:6px}

/* ── Project badge ── */
.bd-project-badge{display:block;text-align:center;font-size:11px;font-weight:600;padding:4px 0;margin-top:6px;border-radius:6px}
.bd-badge--ok{color:#16a34a;background:rgba(22,163,74,.08)}
.bd-badge--exp{color:#dc2626;background:rgba(220,38,38,.06)}

/* ── Responsive ── */
@media(max-width:768px){
    .bd-main{flex-direction:column}
    .bd-preview-panel{position:static;order:-1;width:100%}
    .bd-form-panel{max-height:none;overflow:visible}
    .bd-workspace-bar{flex-wrap:wrap}
    .bd-workspace-bar__right{width:100%;justify-content:space-between}
}

 
/* ── Font size controls ── */
.bd-font-controls{
    display:flex;gap:10px;align-items:end;
    padding:10px 12px;margin-bottom:10px;
    background:linear-gradient(135deg,rgba(99,102,241,0.06),rgba(99,102,241,0.02));
    border:1px solid rgba(99,102,241,0.15);
    border-radius:10px;
}
.bd-font-slider{flex:1;min-width:0}
.bd-font-slider label{
    display:flex;justify-content:space-between;
    font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:4px;
}
.bd-font-slider label span{color:var(--primary-600);font-weight:700}
.bd-font-slider input[type="range"]{
    width:100%;height:5px;accent-color:var(--primary-500);cursor:pointer;
}
 
/* ── Overflow warning ── */
.bd-overflow-warn{
    padding:10px 14px;margin-bottom:10px;
    background:rgba(220,38,38,0.08);
    border:1px solid rgba(220,38,38,0.25);
    border-radius:10px;
    font-size:12px;font-weight:600;color:#dc2626;
    text-align:center;
}
 
/* ── Width selector ── */
.bd-width-select{
    font-size:10px;padding:2px 4px;
    border:1px solid var(--gray-200);border-radius:4px;
    background:var(--bg-primary);color:var(--text-secondary);
    cursor:pointer;margin-right:4px;
}
.bd-width-select:focus{border-color:var(--primary-400);outline:none}
 
/* ── QR controls ── */
.bd-qr-controls{
    margin-top:10px;padding:10px 12px;
    background:rgba(245,158,11,0.06);
    border:1px solid rgba(245,158,11,0.2);
    border-radius:8px;
    display:flex;flex-direction:column;gap:8px;
}
.bd-qr-controls.hidden{display:none}
.bd-qr-ctrl-label{
    font-size:11px;font-weight:700;color:#b45309;
    text-transform:uppercase;letter-spacing:0.5px;margin-bottom:2px;
}
.bd-qr-slider label{
    display:flex;justify-content:space-between;
    font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:3px;
}
.bd-qr-slider label span{color:#b45309;font-weight:700}
.bd-qr-slider input[type="range"]{
    width:100%;height:5px;accent-color:#f59e0b;cursor:pointer;
}
 

/* ── Slot select dropdown ── */
.bd-slot-select{
    font-size:10px;padding:2px 6px;
    border:1px solid var(--gray-200);border-radius:4px;
    background:var(--bg-primary);color:var(--text-secondary);
    cursor:pointer;height:22px;
}
.bd-slot-select:focus{border-color:var(--primary-400);outline:none}
.bd-slot-select option{font-size:11px}

/* ── Photo controls (mirrors QR controls) ── */
.bd-photo-controls{
    margin-top:10px;padding:10px 12px;
    background:rgba(59,130,246,0.06);
    border:1px solid rgba(59,130,246,0.2);
    border-radius:8px;
    display:flex;flex-direction:column;gap:8px;
}
.bd-photo-ctrl-label{
    font-size:11px;font-weight:700;color:#1d4ed8;
    text-transform:uppercase;letter-spacing:0.5px;margin-bottom:2px;
}
.bd-photo-slider label{
    display:flex;justify-content:space-between;
    font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:3px;
}
.bd-photo-slider label span{color:#1d4ed8;font-weight:700}
.bd-photo-slider input[type="range"]{
    width:100%;height:5px;accent-color:#3b82f6;cursor:pointer;
}

/* ── Crop modal ── */
.bd-crop-canvas-wrap{
    position:relative;
    display:flex;align-items:center;justify-content:center;
    background:#111;border-radius:8px;overflow:hidden;
    max-height:55vh;margin:10px 0;
}
.bd-crop-canvas-wrap canvas{
    max-width:100%;max-height:55vh;display:block;cursor:crosshair;
}
.bd-crop-hint{
    font-size:11px;color:var(--text-tertiary);text-align:center;margin-top:4px;
}