/* ============================================================
   L&B Printing — Design Customizer v7 Styles
   Canva-inspired three-zone layout
   ============================================================ */

/* === Reset === */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',sans-serif;overflow:hidden;height:100vh;background:#e5e7eb}

/* === Shared UI === */
.tb{transition:all .12s;cursor:pointer;user-select:none}
.tb:hover{background:#e5e7eb}
.tb.active{background:#0447BC;color:#fff}

/* === Canvas === */
.canvas-area{background:#d1d5db;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.canvas-wrap{position:relative;box-shadow:0 4px 24px rgba(0,0,0,.18);cursor:default}
.canvas-wrap.panning{cursor:grab}
.dim-label{position:absolute;font-size:10px;color:#888;font-weight:500;pointer-events:none;white-space:nowrap}

/* === Coach / Validation === */
.coach-item{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:5px;font-size:11px;cursor:pointer;transition:background .12s}
.coach-item:hover{background:#f3f4f6}
.coach-pass{color:#16a34a}.coach-warn{color:#d97706}.coach-na{color:#9ca3af}

/* === Properties Panel === */
.p-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.p-lbl{font-size:11px;color:#888;width:44px;flex-shrink:0}
.p-in{width:100%;border:1px solid #d1d5db;border-radius:4px;padding:3px 6px;font-size:12px;outline:none}
.p-in:focus{border-color:#0447BC}
.p-in.invalid{border-color:#ef4444;background:#fef2f2}
select.p-in{padding:2px 4px}

/* === Tip Box === */
.tip-box{background:#FFF7ED;border-left:3px solid #FE850A;padding:8px 10px;border-radius:0 5px 5px 0;font-size:11px;color:#1F1D1E}

/* === Range Inputs === */
input[type=range]{-webkit-appearance:none;height:3px;background:#d1d5db;border-radius:2px;outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#0447BC;border-radius:50%;cursor:pointer}

/* === Collapsible Sections === */
.sect-hdr{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;cursor:pointer;user-select:none}
.sect-hdr:hover{background:#f9fafb}
.sect-body{overflow:hidden;transition:max-height .2s}

/* === Thumbnails === */
.thumb-card{border:2px solid transparent;border-radius:5px;overflow:hidden;cursor:pointer;transition:border-color .12s}
.thumb-card.active{border-color:#0447BC}

/* === Dropdowns / Menus === */
.drop-menu{position:absolute;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:100;min-width:140px;padding:4px}
.drop-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:5px;font-size:12px;cursor:pointer;color:#374151}
.drop-item:hover{background:#f3f4f6}

/* === Modals === */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:200}
.modal-box{background:#fff;border-radius:12px;max-height:90vh;overflow-y:auto}

/* === Layers === */
.layer-row{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:11px;transition:background .1s}
.layer-row:hover{background:#f3f4f6}
.layer-row.selected{background:#eff6ff;outline:1px solid #bfdbfe}

/* === Icon Buttons === */
.icon-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:3px;cursor:pointer;color:#9ca3af;flex-shrink:0}
.icon-btn:hover{background:#e5e7eb;color:#374151}

/* === Tabs === */
.tab-btn{padding:6px 16px;font-size:12px;font-weight:600;border-bottom:2px solid transparent;cursor:pointer;color:#6b7280}
.tab-btn.active{color:#0447BC;border-bottom-color:#0447BC}

/* === Alignment Buttons === */
.align-btn{width:28px;height:26px;display:flex;align-items:center;justify-content:center;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;background:#fff}
.align-btn:hover{background:#f3f4f6}
.align-btn.active{background:#0447BC;border-color:#0447BC;color:#fff}

/* === Mode Toggle (legacy — kept for admin) === */
.mode-toggle{display:inline-flex;border-radius:6px;overflow:hidden;border:1px solid #4b5563}
.mode-toggle button{padding:3px 12px;font-size:10px;font-weight:600;background:transparent;color:#9ca3af;border:none;cursor:pointer;transition:all .15s}
.mode-toggle button.active{background:#0447BC;color:#fff}
.mode-toggle button.admin-active{background:#FE850A;color:#fff}

/* === Template Cards === */
.tpl-card{border:2px solid #e5e7eb;border-radius:10px;overflow:hidden;cursor:pointer;transition:all .15s;background:#fff;perspective:600px}
.tpl-card:hover{border-color:#0447BC;box-shadow:0 4px 16px rgba(0,0,0,.12)}
.tpl-card.coming{opacity:.5;pointer-events:none;position:relative}
.tpl-card.coming::after{content:'Coming Soon';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.7);font-size:11px;font-weight:700;color:#6b7280;z-index:2}
.tpl-card__preview{position:relative;height:220px;overflow:hidden}
.tpl-card__inner{position:relative;width:100%;height:100%;transition:transform .5s ease;transform-style:preserve-3d}
.tpl-card:hover .tpl-card__inner{transform:rotateY(180deg)}
.tpl-card__front,.tpl-card__back{position:absolute;inset:0;backface-visibility:hidden;display:flex;align-items:center;justify-content:center;overflow:hidden}
.tpl-card__back{transform:rotateY(180deg)}
.tpl-card__front canvas,.tpl-card__back canvas,.tpl-card__front img,.tpl-card__back img{width:100%;height:100%;object-fit:contain;background:#f3f4f6}
.tpl-card__info{padding:10px 12px}
.tpl-card__flip-hint{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.55);color:#fff;font-size:9px;padding:2px 6px;border-radius:4px;opacity:0;transition:opacity .2s;pointer-events:none}
.tpl-card:hover .tpl-card__flip-hint{opacity:1}
.tpl-card__start-btn{display:block;width:100%;padding:7px 0;text-align:center;font-size:11px;font-weight:600;color:#0447BC;background:#eff6ff;border-top:1px solid #e5e7eb;cursor:pointer;transition:background .15s}
.tpl-card__start-btn:hover{background:#dbeafe}
.tpl-thumb{height:220px;display:flex;align-items:center;justify-content:center;font-size:32px}

/* === Save Indicator === */
.save-indicator{display:flex;align-items:center;gap:4px;font-size:10px;color:#9ca3af;transition:color .2s}
.save-indicator.saving{color:#FE850A}
.save-indicator.saved{color:#16a34a}
.save-indicator .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* === EDDM Zone === */
.eddm-zone-overlay{pointer-events:none;position:absolute}

/* === Forms === */
.form-group{margin-bottom:12px}
.form-label{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:#374151;margin-bottom:4px}
.form-label .req{color:#ef4444}
.form-input{width:100%;border:1px solid #d1d5db;border-radius:5px;padding:6px 8px;font-size:12px;outline:none;transition:border-color .15s}
.form-input:focus{border-color:#0447BC}
.form-input.invalid{border-color:#ef4444;background:#fef2f2}
.form-textarea{resize:vertical;min-height:60px}

/* === Image Upload Zone === */
.img-upload-zone{border:2px dashed #d1d5db;border-radius:8px;padding:12px;text-align:center;cursor:pointer;transition:all .15s}
.img-upload-zone:hover{border-color:#0447BC;background:#f8faff}
.img-upload-zone.has-image{border-style:solid;border-color:#d1d5db}
.img-upload-zone.compact{padding:6px 8px;border-radius:6px}
.img-upload-zone.compact img{max-height:48px;max-width:100%;border-radius:3px;display:block;margin:0 auto}
.img-upload-zone.compact .replace-hint{font-size:8px;color:#9ca3af;margin-top:2px}

/* === Logo Options === */
.logo-option{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:5px;cursor:pointer;font-size:11px;border:1px solid transparent}
.logo-option:hover{background:#f3f4f6}
.logo-option.selected{background:#eff6ff;border-color:#bfdbfe}
.logo-swatch{width:32px;height:20px;border-radius:3px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:6px;font-weight:700}

/* === Form Sections === */
.form-section-hdr{font-size:10px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;padding:8px 0 4px;border-top:1px solid #f3f4f6;margin-top:8px}
.form-section-hdr:first-child{border-top:none;margin-top:0}
.completion-bar{height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden}
.completion-fill{height:100%;background:#16a34a;border-radius:2px;transition:width .3s}

/* === Admin Mode === */
.admin-border{outline:3px solid #FE850A;outline-offset:-3px}
.admin-badge{position:fixed;top:48px;right:12px;background:#FE850A;color:#fff;font-size:9px;font-weight:800;padding:2px 8px;border-radius:0 0 4px 4px;z-index:60;letter-spacing:.05em}
.field-placeholder{border:2px dashed;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#666;background:rgba(255,255,255,.85)}
.admin-tool-btn{width:100%;padding:8px 6px;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:10px;font-weight:600;text-align:center;transition:all .15s;background:#fff;color:#374151}
.admin-tool-btn:hover{border-color:#FE850A;background:#FFF7ED}
.linked-field-row{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:4px;cursor:pointer;font-size:11px;transition:background .1s;border:1px solid transparent}
.linked-field-row:hover{background:#f3f4f6}
.linked-field-row.selected{background:#FFF7ED;border-color:#FE850A}
.field-type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.tpl-lib-card{border:1px solid #e5e7eb;border-radius:8px;padding:10px;display:flex;gap:10px;align-items:center;transition:all .15s;cursor:pointer}
.tpl-lib-card:hover{border-color:#FE850A;background:#FFFBF5}
.font-cat-hdr{font-size:9px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;padding:4px 6px 2px}
.field-lock-badge{font-size:8px;font-weight:700;padding:1px 4px;border-radius:3px;text-transform:uppercase;letter-spacing:.03em}
.lock-org{background:#fee2e2;color:#dc2626}
.lock-agent{background:#dbeafe;color:#2563eb}
.lock-design{background:#f3f4f6;color:#6b7280}

/* === Dashboard === */
.dash-card{border:1px solid #e5e7eb;border-radius:10px;padding:16px;background:#fff;transition:all .15s}
.dash-card:hover{border-color:#0447BC;box-shadow:0 2px 8px rgba(0,0,0,.08)}

/* === User Pill === */
.user-pill{display:flex;align-items:center;gap:6px;padding:2px 8px 2px 2px;border-radius:20px;background:#374151;cursor:pointer;transition:background .15s}
.user-pill:hover{background:#4b5563}
.user-pill .avatar{width:20px;height:20px;border-radius:50%;background:#0447BC;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff}
.user-pill .avatar-img{width:20px;height:20px;border-radius:50%;object-fit:cover}

/* === Onboarding === */
.onboard-bg{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:250}
.onboard-box{background:#fff;border-radius:16px;width:560px;max-height:90vh;overflow-y:auto;padding:0}
.onboard-step{display:none}.onboard-step.active{display:block}
.step-dots{display:flex;gap:8px;justify-content:center;margin-top:16px}
.step-dot{width:10px;height:10px;border-radius:50%;background:#e5e7eb;transition:all .2s}
.step-dot.active{background:#0447BC;transform:scale(1.2)}.step-dot.done{background:#16a34a}
.headshot-upload{width:160px;height:160px;border-radius:50%;border:3px dashed #d1d5db;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;margin:0 auto;overflow:hidden;background:#f9fafb}
.headshot-upload:hover{border-color:#0447BC;background:#f0f7ff}
.headshot-upload.has-image{border-style:solid;border-color:#16a34a}
.headshot-upload img{width:100%;height:100%;object-fit:cover}
.profile-summary{border:1px solid #e5e7eb;border-radius:10px;padding:12px;margin-bottom:8px}
.profile-row{display:flex;align-items:center;gap:10px;font-size:12px;padding:4px 0}
.profile-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb;flex-shrink:0}
.profile-avatar-placeholder{width:48px;height:48px;border-radius:50%;background:#0447BC;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}
.org-summary{border:1px solid #e5e7eb;border-radius:10px;padding:12px;margin-bottom:8px;background:#f9fafb}
.listing-section{border:1px solid #0447BC;border-radius:10px;padding:12px;background:#f8faff}
.quick-start-card{border:1px solid #e5e7eb;border-radius:10px;padding:16px;background:#fff;cursor:pointer;transition:all .15s;text-align:center}
.quick-start-card:hover{border-color:#0447BC;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.completeness-banner{background:#FFF7ED;border:1px solid #FED7AA;border-radius:10px;padding:12px 16px;margin-bottom:16px}

/* === Cropper Modal === */
.cropper-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:300}
.cropper-modal-box{background:#fff;border-radius:14px;width:560px;max-width:94vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}
.cropper-container-area{height:360px;background:#111;overflow:hidden;position:relative}
.cropper-container-area img{max-width:100%;display:block}
.cropper-view-box,.cropper-face{border-radius:50%}
.cropper-controls{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid #e5e7eb}
.cropper-ctrl-btn{padding:6px 14px;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer;font-size:11px;font-weight:500;transition:all .15s}
.cropper-ctrl-btn:hover{background:#f3f4f6;border-color:#9ca3af}

/* === Toast === */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:#1F1D1E;color:#fff;padding:10px 20px;border-radius:8px;font-size:13px;font-weight:500;z-index:999;opacity:0;transition:all .3s ease;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.2);display:flex;align-items:center;gap:8px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.success{background:#16a34a}.toast.error{background:#dc2626}.toast.info{background:#0447BC}

/* ============================================================
   v7: Canva-inspired Layout — Icon Sidebar + Drawer + Canvas
   ============================================================ */

/* --- Top Nav Bar --- */
.v7-topnav{
  height:52px;background:#1F1D1E;color:#fff;display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;user-select:none;flex-shrink:0;z-index:50;position:relative;
}
.v7-topnav__section{display:flex;align-items:center;gap:10px}
.v7-topnav__center{position:absolute;left:50%;transform:translateX(-50%)}
.v7-topnav__back{color:#fff;padding:6px;border-radius:6px;display:flex;align-items:center;transition:background .12s;cursor:pointer;text-decoration:none}
.v7-topnav__back:hover{background:#374151}
.v7-topnav__divider{width:1px;height:20px;background:#4b5563}
.v7-topnav__badge{font-size:12px;font-weight:600;color:#e5e7eb;padding:5px 12px;border-radius:8px;background:#374151;letter-spacing:.01em}
.v7-topnav__campaign{display:flex;align-items:center;gap:4px;cursor:text;padding:2px 4px;border-radius:6px;transition:background .12s}
.v7-topnav__campaign:hover{background:#374151}
.v7-topnav__campaign-input{background:transparent;border:none;color:#fff;font-size:13px;font-weight:500;outline:none;width:160px}
.v7-topnav__pencil{color:#6b7280;flex-shrink:0}
.v7-topnav__icon-btn{color:#fff;padding:6px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;transition:background .12s}
.v7-topnav__icon-btn:hover{background:#374151}
.v7-topnav__preview-btn{color:#fff;padding:5px 14px;border-radius:6px;font-size:12px;font-weight:600;border:1px solid #6b7280;background:transparent;cursor:pointer;transition:all .15s}
.v7-topnav__preview-btn:hover{border-color:#fff;background:#374151}
.v7-topnav__signin-btn{color:#9ca3af;padding:5px 12px;border-radius:6px;font-size:11px;font-weight:500;border:none;background:transparent;cursor:pointer;transition:all .15s}
.v7-topnav__signin-btn:hover{color:#fff;background:#374151}
.v7-topnav__admin-btn{color:#FE850A;padding:4px 10px;border-radius:4px;font-size:10px;font-weight:700;border:1px solid #FE850A;background:transparent;cursor:pointer;margin-left:8px}
.v7-topnav__admin-btn:hover{background:#FE850A;color:#fff}

/* --- Mode Toggle (v7 style) --- */
.v7-mode-toggle{display:inline-flex;border-radius:8px;overflow:hidden;background:#374151;padding:2px}
.v7-mode-toggle button{padding:6px 18px;font-size:12px;font-weight:600;background:transparent;color:#9ca3af;border:none;cursor:pointer;transition:all .15s;border-radius:6px}
.v7-mode-toggle button.active{background:#0447BC;color:#fff}
.v7-mode-toggle button.admin-active{background:#FE850A;color:#fff}

/* Front/Back toggle pills */
.v7-side-toggle{display:flex;border-radius:6px;overflow:hidden;border:1px solid #d1d5db;background:#f9fafb}
.v7-side-toggle button{padding:4px 14px;font-size:11px;font-weight:600;background:transparent;color:#9ca3af;border:none;cursor:pointer;transition:all .15s}
.v7-side-toggle button.active{background:#0447BC;color:#fff}

/* --- Main Layout --- */
.v7-main{display:flex;height:calc(100vh - 52px);overflow:hidden}

/* --- Icon Sidebar --- */
.v7-sidebar{
  width:72px;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;
  align-items:center;padding:12px 0 8px;gap:2px;flex-shrink:0;z-index:40;user-select:none;
}
.v7-sidebar__icon{
  width:56px;padding:10px 0 6px;display:flex;flex-direction:column;align-items:center;gap:3px;
  border-radius:10px;cursor:pointer;color:#6b7280;font-size:10px;font-weight:500;transition:all .12s;
  border:2px solid transparent;letter-spacing:.01em;
}
.v7-sidebar__icon:hover{background:#f3f4f6;color:#374151}
.v7-sidebar__icon.active{background:#eff6ff;color:#0447BC;border-color:#bfdbfe}
.v7-sidebar__icon svg{width:22px;height:22px}
.v7-sidebar__spacer{flex:1}

/* --- Drawer Panel --- */
.v7-drawer{
  width:0;overflow:hidden;background:#fff;border-right:1px solid #e5e7eb;
  transition:width .2s ease;flex-shrink:0;display:flex;flex-direction:column;z-index:30;
  height:100%;min-height:0;
}
.v7-drawer.open{width:320px}
.v7-drawer__header{
  padding:14px 16px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
}
.v7-drawer__title{font-size:14px;font-weight:700;color:#1F1D1E}
.v7-drawer__close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;color:#9ca3af;font-size:18px}
.v7-drawer__close:hover{background:#f3f4f6;color:#374151}
.v7-drawer__body{flex:1;overflow-y:auto;padding:14px 16px;min-height:0}
.v7-drawer__panel{display:none}
.v7-drawer__panel.active{display:flex;flex-direction:column;flex:1;min-height:0}

/* --- Template grid (2-col) --- */
.v7-tpl-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.v7-tpl-card{border:2px solid #e5e7eb;border-radius:10px;overflow:hidden;cursor:pointer;transition:all .15s;background:#fff}
.v7-tpl-card:hover{border-color:#0447BC;box-shadow:0 2px 12px rgba(0,0,0,.1)}
.v7-tpl-card__preview{height:110px;display:flex;align-items:center;justify-content:center;padding:12px;overflow:hidden}
.v7-tpl-card__thumb{text-align:left}
.v7-tpl-card__info{padding:8px 10px;border-top:1px solid #f3f4f6}
.v7-tpl-card__name{font-size:11px;font-weight:600;color:#1F1D1E;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.v7-tpl-card__industry{font-size:9px;font-weight:600;text-transform:capitalize;margin-top:1px}

/* --- Filter pills --- */
.v7-filter-pill{padding:4px 12px;border-radius:20px;font-size:11px;font-weight:500;background:#f3f4f6;color:#6b7280;border:none;cursor:pointer;transition:all .12s}
.v7-filter-pill:hover{background:#e5e7eb;color:#374151}
.v7-filter-pill.active{background:#0447BC;color:#fff}

/* --- Element buttons --- */
.v7-element-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 6px;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;background:#fff;transition:all .15s;font-size:10px;font-weight:500;color:#374151}
.v7-element-btn:hover{border-color:#0447BC;background:#f8faff}
.v7-element-card{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .15s;background:#f9fafb}
.v7-element-card:hover{border-color:#0447BC;background:#eff6ff}

/* --- Canvas Workspace --- */
.v7-workspace{flex:1;display:flex;flex-direction:column;overflow:hidden}
.v7-canvas-area{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#e5e7eb}

/* --- Legend strip --- */
.v7-legend-strip{display:flex;align-items:center;gap:12px;padding:6px 16px;background:#fff;border-bottom:1px solid #f3f4f6;flex-shrink:0;font-size:11px;color:#6b7280}
.v7-legend-item{display:flex;align-items:center;gap:4px;font-weight:500}
.v7-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* --- Canvas Bottom Strip --- */
.v7-canvas-strip{
  height:40px;background:#fff;border-top:1px solid #e5e7eb;display:flex;align-items:center;
  justify-content:space-between;padding:0 16px;flex-shrink:0;user-select:none;
}
.v7-strip__group{display:flex;align-items:center;gap:6px}
.v7-strip__toggle{
  padding:3px 10px;font-size:10px;font-weight:600;border-radius:4px;cursor:pointer;
  color:#9ca3af;transition:all .12s;border:1px solid transparent;
}
.v7-strip__toggle:hover{background:#f3f4f6;color:#374151}
.v7-strip__toggle.active{color:#0447BC;background:#eff6ff;border-color:#bfdbfe}
.v7-strip__subtle{font-size:10px;color:#9ca3af}
.v7-strip__subtle.active{color:#374151;background:transparent;border-color:transparent;font-weight:600}

/* Zoom controls */
.v7-zoom-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;font-size:14px;color:#374151;transition:all .12s}
.v7-zoom-btn:hover{background:#f3f4f6;border-color:#d1d5db}
.v7-zoom-slider{width:80px}

/* Thumbnails */
.v7-thumb{border:2px solid #e5e7eb;border-radius:6px;overflow:hidden;cursor:pointer;transition:border-color .12s}
.v7-thumb.active{border-color:#0447BC}
.v7-thumb__label{font-size:9px;text-align:center;color:#6b7280;padding:2px 0;font-weight:500}

/* --- Context Bar (fixed at top of canvas) --- */
.v7-context-bar{
  display:none;align-items:center;gap:6px;padding:6px 12px;
  background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;
  white-space:nowrap;overflow-x:auto;overflow-y:hidden;
  scrollbar-width:none;
}
.v7-context-bar::-webkit-scrollbar{display:none}
.v7-context-bar.visible{display:flex}
.v7-ctx__btn{
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  border-radius:5px;cursor:pointer;color:#374151;border:none;background:transparent;
  font-size:12px;flex-shrink:0;transition:all .1s;
}
.v7-ctx__btn:hover{background:#f3f4f6}
.v7-ctx__btn.active{background:#0447BC;color:#fff}
.v7-ctx__btn--danger{color:#ef4444}
.v7-ctx__btn--danger:hover{background:#fef2f2}
.v7-ctx__sep{width:1px;height:22px;background:#e5e7eb;flex-shrink:0;margin:0 2px}
.v7-ctx__spacer{flex:1;min-width:8px}
.v7-ctx__label{font-size:10px;color:#6b7280;font-weight:500;flex-shrink:0;white-space:nowrap}
.v7-ctx__select{
  border:1px solid #e5e7eb;border-radius:6px;padding:4px 8px;font-size:11px;outline:none;
  max-width:150px;background:#fff;flex-shrink:0;
}
.v7-ctx__input{
  border:1px solid #e5e7eb;border-radius:6px;padding:4px 6px;font-size:11px;outline:none;width:44px;
  text-align:center;flex-shrink:0;
}
.v7-ctx__input:focus{border-color:#0447BC}
.v7-ctx__color{width:26px;height:26px;border-radius:6px;cursor:pointer;border:2px solid #e5e7eb;padding:0;background:transparent;flex-shrink:0}
.v7-ctx__range{width:60px;flex-shrink:0}
.v7-ctx__badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;flex-shrink:0}
.v7-ctx__badge--ok{background:#dcfce7;color:#16a34a}
.v7-ctx__badge--warn{background:#fef9c3;color:#ca8a04}

/* --- Coach Badge (top nav) --- */
.v7-coach-badge{
  position:relative;cursor:pointer;padding:4px;border-radius:6px;transition:background .12s;
}
.v7-coach-badge:hover{background:#374151}
.v7-coach-badge__count{
  position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;border-radius:8px;
  background:#ef4444;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;
  justify-content:center;padding:0 4px;
}
.v7-coach-badge__count.ok{background:#16a34a}
.v7-coach-dropdown{
  position:absolute;top:40px;right:0;width:280px;background:#fff;border:1px solid #e5e7eb;
  border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.15);padding:12px;display:none;z-index:200;color:#1F1D1E;
}
.v7-coach-dropdown.open{display:block}
.v7-coach-dropdown__score{font-size:12px;font-weight:700;color:#1F1D1E;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}

/* --- Review & Export CTA --- */
.v7-cta{
  background:#FE850A;color:#fff;padding:8px 20px;border-radius:8px;font-size:13px;font-weight:700;
  cursor:pointer;border:none;transition:all .15s;white-space:nowrap;letter-spacing:.01em;
}
.v7-cta:hover{filter:brightness(1.1)}

/* --- Get Design Help floating button --- */
.v7-design-help{
  position:fixed;bottom:24px;left:96px;
  display:flex;align-items:center;gap:8px;padding:10px 20px;
  background:#FE850A;color:#fff;border-radius:24px;font-size:13px;font-weight:600;
  text-decoration:none;box-shadow:0 4px 16px rgba(254,133,10,.35);
  transition:all .2s;z-index:60;cursor:pointer;
}
.v7-design-help:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(254,133,10,.45)}
.v7-design-help__close{
  display:flex;align-items:center;justify-content:center;
  width:20px;height:20px;margin-left:4px;border-radius:50%;
  background:rgba(255,255,255,.25);border:none;color:#fff;
  cursor:pointer;font-size:14px;line-height:1;transition:background .15s;padding:0;
}
.v7-design-help__close:hover{background:rgba(255,255,255,.45)}

/* --- Range input fix for smooth dragging --- */
.v7-range{-webkit-appearance:none;height:4px;background:#e5e7eb;border-radius:2px;outline:none;cursor:pointer}
.v7-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#0447BC;border-radius:50%;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.v7-range::-moz-range-thumb{width:14px;height:14px;background:#0447BC;border-radius:50%;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.15)}

/* --- Responsive --- */
@media(max-width:1023px){
  .v7-sidebar__icon span{display:none}
  .v7-sidebar{width:52px;padding:8px 0}
  .v7-sidebar__icon{width:44px;padding:8px 0}
  .v7-drawer.open{position:absolute;left:52px;top:0;bottom:0;box-shadow:8px 0 24px rgba(0,0,0,.1)}
  .v7-topnav__center{position:static;transform:none}
  .v7-topnav__campaign-input{width:100px}
}
@media(max-width:767px){
  .v7-main{flex-direction:column}
  .v7-sidebar{display:none}
  .v7-drawer{display:none}
  .v7-mobile-warning{display:flex !important}
  .v7-design-help{display:none}
}

/* Mobile warning overlay */
.v7-mobile-warning{
  display:none;position:fixed;inset:0;background:#fff;z-index:500;
  flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center;
}
