@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:#F7F8FA;color:#111827;line-height:1.6;min-height:100vh}

/* Header/footer/nav handled by style.css */

/* === HERO / TOOL PAGE === */
.tool-hero{background:#fff;border-bottom:1px solid #E5E7EB;padding:40px 24px 0}
.tool-hero-inner{max-width:1140px;margin:0 auto}
.tool-hero h1{font-size:1.75rem;font-weight:800;color:#111827;margin-bottom:6px}
.tool-hero p{color:#6B7280;font-size:.975rem;margin-bottom:24px}
.type-tabs{display:flex;gap:6px;flex-wrap:wrap;border-bottom:2px solid #E5E7EB;padding-bottom:0;margin-bottom:0}
.type-tab{padding:9px 16px;border:none;background:none;font-family:'Outfit',sans-serif;font-size:.875rem;font-weight:600;color:#6B7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;border-radius:6px 6px 0 0}
.type-tab:hover{color:#111827;background:#F9FAFB}
.type-tab.active{color:#4f46e5;border-bottom-color:#4f46e5}

/* === MAIN LAYOUT === */
.generator-layout{max-width:1140px;margin:0 auto;padding:32px 24px;display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start}
@media(max-width:900px){.generator-layout{grid-template-columns:1fr}}

/* === FORM PANEL === */
.form-panel{background:#fff;border-radius:16px;border:1.5px solid #E5E7EB;padding:28px}
.field-group{margin-bottom:18px}
.field-group:last-child{margin-bottom:0}
.field-group label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:6px}
.field-group input,.field-group textarea,.field-group select{width:100%;padding:10px 14px;border:1.5px solid #E5E7EB;border-radius:10px;font-family:'Outfit',sans-serif;font-size:.9rem;color:#111827;background:#fff;transition:border-color .15s;outline:none}
.field-group input:focus,.field-group textarea:focus,.field-group select:focus{border-color:#4f46e5;box-shadow:0 0 0 3px rgba(79,70,229,.1)}
.field-group textarea{resize:vertical;min-height:100px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Customization */
.custom-section{margin-top:24px;padding-top:20px;border-top:1.5px solid #F3F4F6}
.custom-section .section-label{font-size:.8rem;font-weight:700;color:#9CA3AF;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
.color-row{display:flex;gap:16px}
.color-pick{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#374151;font-weight:500}
.color-pick input[type=color]{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;padding:2px;background:none}
.size-row{display:flex;align-items:center;gap:12px;margin-top:14px}
.size-row label{font-size:.875rem;color:#374151;font-weight:500;flex-shrink:0}
.size-row input[type=range]{flex:1;accent-color:#4f46e5}
.size-val{font-size:.85rem;color:#4f46e5;font-weight:700;min-width:45px}
.logo-row{margin-top:14px}
.logo-row label{font-size:.875rem;color:#374151;font-weight:500;display:block;margin-bottom:6px}
.logo-upload{display:flex;align-items:center;gap:10px}
.btn-logo{padding:7px 14px;border:1.5px solid #E5E7EB;border-radius:8px;background:#fff;font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:600;color:#374151;cursor:pointer;transition:all .15s}
.btn-logo:hover{border-color:#4f46e5;color:#4f46e5}
.logo-name{font-size:.8rem;color:#9CA3AF}

/* === PREVIEW PANEL === */
.preview-panel{position:sticky;top:78px}
.preview-card{background:#fff;border-radius:16px;border:1.5px solid #E5E7EB;padding:28px;text-align:center}
.preview-card h2{font-size:.875rem;font-weight:700;color:#374151;margin-bottom:20px;text-align:left}
.qr-canvas-wrap{display:flex;align-items:center;justify-content:center;background:#F9FAFB;border-radius:12px;padding:20px;margin-bottom:20px;min-height:200px}
#qrCanvas{border-radius:8px;max-width:100%;height:auto}
.qr-empty{color:#D1D5DB;font-size:.875rem}
.dl-btns{display:flex;gap:8px}
.btn-dl{flex:1;padding:10px 0;border-radius:10px;font-family:'Outfit',sans-serif;font-size:.875rem;font-weight:700;cursor:pointer;border:none;transition:all .15s}
.btn-dl-png{background:#4f46e5;color:#fff}
.btn-dl-png:hover{background:#4338ca}
.btn-dl-svg{background:#F3F4F6;color:#374151;border:1.5px solid #E5E7EB}
.btn-dl-svg:hover{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}
.btn-dl:disabled{opacity:.4;cursor:not-allowed}
.qr-hint{font-size:.78rem;color:#9CA3AF;margin-top:12px;line-height:1.5}

/* === SCANNER PAGE === */
.scan-layout{max-width:780px;margin:0 auto;padding:40px 24px}
.scan-card{background:#fff;border-radius:16px;border:1.5px solid #E5E7EB;padding:32px}
.scan-tabs{display:flex;gap:8px;margin-bottom:28px}
.scan-tab{flex:1;padding:10px;border:1.5px solid #E5E7EB;border-radius:10px;background:#fff;font-family:'Outfit',sans-serif;font-size:.875rem;font-weight:600;color:#6B7280;cursor:pointer;transition:all .15s;text-align:center}
.scan-tab.active{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}
.dropzone{border:2px dashed #D1D5DB;border-radius:14px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s;background:#F9FAFB}
.dropzone:hover,.dropzone.drag-over{border-color:#4f46e5;background:#eef2ff}
.dz-icon{color:#D1D5DB;margin-bottom:12px}
.dz-icon svg{width:40px;height:40px}
.dz-title{font-size:1rem;font-weight:700;color:#374151;margin-bottom:4px}
.dz-sub{font-size:.85rem;color:#9CA3AF}
.btn-choose{display:inline-block;margin-top:14px;padding:8px 20px;background:#4f46e5;color:#fff;border-radius:8px;font-weight:700;font-size:.875rem;cursor:pointer;transition:background .15s}
.btn-choose:hover{background:#4338ca}
.camera-wrap{position:relative;border-radius:14px;overflow:hidden;background:#000;aspect-ratio:4/3}
#cameraVideo{width:100%;height:100%;object-fit:cover;display:block}
.camera-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
.scan-frame{width:200px;height:200px;border:3px solid #4f46e5;border-radius:12px;box-shadow:0 0 0 9999px rgba(0,0,0,.4)}
.scan-result{margin-top:24px;padding:20px;background:#eef2ff;border-radius:12px;border:1.5px solid #a5b4fc;display:none}
.scan-result.error{background:#FEF2F2;border-color:#FECACA}
.scan-result-label{font-size:.78rem;font-weight:700;color:#4f46e5;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.scan-result.error .scan-result-label{color:#DC2626}
.scan-result-text{font-size:.95rem;color:#111827;word-break:break-all;font-weight:500}
.scan-actions{display:flex;gap:8px;margin-top:12px}
.btn-copy,.btn-open{padding:7px 16px;border-radius:8px;font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .15s;border:none}
.btn-copy{background:#4f46e5;color:#fff}
.btn-copy:hover{background:#4338ca}
.btn-open{background:#F3F4F6;color:#374151}
.btn-open:hover{background:#E5E7EB}
.btn-stop-cam{display:block;width:100%;margin-top:12px;padding:10px;background:#FEF2F2;border:1.5px solid #FECACA;border-radius:10px;font-family:'Outfit',sans-serif;font-size:.875rem;font-weight:700;color:#DC2626;cursor:pointer;transition:all .15s}
.btn-stop-cam:hover{background:#FEE2E2}

/* === HOMEPAGE === */
.home-hero{background:linear-gradient(135deg,#3730a3 0%,#3730a3 50%,#4338ca 100%);padding:64px 24px;text-align:center;color:#fff}
.home-hero h1{font-size:2.4rem;font-weight:800;margin-bottom:12px;line-height:1.2}
.home-hero p{font-size:1.05rem;opacity:.85;max-width:520px;margin:0 auto 32px}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-hero-primary{padding:13px 28px;background:#fff;color:#4f46e5;border-radius:10px;font-weight:800;font-size:1rem;text-decoration:none;transition:all .15s}
.btn-hero-primary:hover{background:#eef2ff}
.btn-hero-secondary{padding:13px 28px;background:rgba(255,255,255,.15);color:#fff;border-radius:10px;font-weight:700;font-size:1rem;text-decoration:none;border:1.5px solid rgba(255,255,255,.3);transition:all .15s}
.btn-hero-secondary:hover{background:rgba(255,255,255,.25)}
.tools-grid{max-width:1140px;margin:0 auto;padding:56px 24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.tool-card{background:#fff;border-radius:14px;border:1.5px solid #E5E7EB;padding:24px;text-decoration:none;color:inherit;transition:all .2s;display:flex;align-items:flex-start;gap:14px}
.tool-card:hover{border-color:#4f46e5;box-shadow:0 8px 24px rgba(79,70,229,.1);transform:translateY(-2px)}
.tool-card-icon{width:42px;height:42px;border-radius:10px;background:#eef2ff;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#4f46e5}
.tool-card-icon svg{width:20px;height:20px}
.tool-card-body h3{font-size:.95rem;font-weight:700;color:#111827;margin-bottom:3px}
.tool-card-body p{font-size:.82rem;color:#6B7280;line-height:1.45}
.section-title{text-align:center;font-size:1.5rem;font-weight:800;color:#111827;margin-bottom:8px}
.section-sub{text-align:center;font-size:.95rem;color:#6B7280;margin-bottom:0}

/* === LANDING PAGES (dedicated tool pages) === */
.lp-hero{background:linear-gradient(150deg,#eef2ff 0%,#f5f3ff 100%);padding:80px 24px;text-align:center;border-bottom:1px solid #a5b4fc}
.lp-hero-inner{max-width:680px;margin:0 auto}
.lp-hero h1{font-size:2.25rem;font-weight:800;color:#111827;line-height:1.2;margin-bottom:14px}
@media(max-width:600px){.lp-hero h1{font-size:1.65rem}}
.lp-hero p{color:#4B5563;font-size:1.05rem;max-width:540px;margin:0 auto 32px}
.lp-hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.lp-btn{display:inline-block;background:#4f46e5;color:#fff;font-family:'Outfit',sans-serif;font-size:1rem;font-weight:700;padding:13px 28px;border-radius:12px;text-decoration:none;transition:background .15s}
.lp-btn:hover{background:#4338ca}
.lp-btn-outline{display:inline-block;border:2px solid #4f46e5;color:#4f46e5;font-family:'Outfit',sans-serif;font-size:1rem;font-weight:700;padding:11px 24px;border-radius:12px;text-decoration:none;transition:all .15s}
.lp-btn-outline:hover{background:#4f46e5;color:#fff}
.lp-section{padding:64px 24px}
.lp-alt{background:#fff}
.lp-inner{max-width:1000px;margin:0 auto}
.lp-inner>h2{font-size:1.5rem;font-weight:800;color:#111827;margin-bottom:32px;text-align:center}
.lp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:680px){.lp-steps{grid-template-columns:1fr}}
.lp-step{background:#F9FAFB;border-radius:14px;padding:24px;border:1.5px solid #E5E7EB}
.lp-num{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:#4f46e5;color:#fff;font-weight:800;font-size:.95rem;border-radius:50%;margin-bottom:12px}
.lp-step strong{display:block;font-size:.975rem;font-weight:700;color:#111827;margin-bottom:4px}
.lp-step p{font-size:.875rem;color:#6B7280;margin:0;line-height:1.5}
.lp-benefits{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:14px;max-width:640px;margin:0 auto}
@media(max-width:560px){.lp-benefits{grid-template-columns:1fr}}
.lp-benefits li{display:flex;align-items:flex-start;gap:10px;font-size:.95rem;color:#374151;padding:14px;background:#F9FAFB;border-radius:10px;border:1px solid #E5E7EB}
.lp-benefits li::before{content:"✓";font-weight:800;color:#4f46e5;flex-shrink:0;font-size:1rem}
.lp-article-card{background:#f5f3ff;border:1.5px solid #a5b4fc;border-radius:14px;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;text-decoration:none;max-width:600px;margin:0 auto;transition:all .15s}
.lp-article-card:hover{border-color:#4f46e5;box-shadow:0 4px 12px rgba(79,70,229,.12)}
.lp-article-card-text span{font-size:.8rem;font-weight:700;color:#4f46e5;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:4px}
.lp-article-card-text strong{font-size:.975rem;font-weight:700;color:#111827}
.lp-faq{max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:20px}
.lp-faq-item{border-bottom:1px solid #E5E7EB;padding-bottom:20px}
.lp-faq-item:last-child{border-bottom:none;padding-bottom:0}
.lp-faq-item h3{font-size:.975rem;font-weight:700;color:#111827;margin-bottom:6px}
.lp-faq-item p{font-size:.9rem;color:#6B7280;margin:0;line-height:1.6}
.lp-cta-band{background:#4f46e5;padding:64px 24px;text-align:center;margin-top:0}
.lp-cta-band h2{color:#fff;font-size:1.75rem;font-weight:800;margin-bottom:10px}
.lp-cta-band p{color:#a5b4fc;margin-bottom:28px;font-size:1rem}
.lp-btn-white{display:inline-block;background:#fff;color:#4f46e5;font-family:'Outfit',sans-serif;font-size:1rem;font-weight:700;padding:13px 28px;border-radius:12px;text-decoration:none;transition:all .15s}
.lp-btn-white:hover{background:#f5f3ff}

/* Footer handled by style.css */

/* === SEO SECTION === */
.seo-section{background:#fff;border-top:1px solid #E5E7EB;padding:56px 24px}
.seo-inner{max-width:800px;margin:0 auto}
.seo-inner h2{font-size:1.3rem;font-weight:800;color:#111827;margin-bottom:12px;margin-top:32px}
.seo-inner h2:first-child{margin-top:0}
.seo-inner p{color:#4B5563;line-height:1.75;margin-bottom:12px;font-size:.95rem}

/* === DOT STYLE BUTTONS === */
.dot-style-row{margin-top:14px}
.dot-style-row label,.ec-row label{font-size:.875rem;color:#374151;font-weight:500;display:block;margin-bottom:8px}
.dot-style-btns,.ec-btns{display:flex;gap:8px;flex-wrap:wrap}
.dot-btn,.ec-btn{flex:1;min-width:0;padding:8px 10px;border:1.5px solid #E5E7EB;border-radius:9px;background:#fff;font-family:'Outfit',sans-serif;font-size:.8rem;font-weight:600;color:#374151;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s;line-height:1}
.dot-btn:hover,.ec-btn:hover{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}
.dot-btn.active,.ec-btn.active{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}
.dot-btn svg{width:16px;height:16px;flex-shrink:0}

/* === EC LEVEL ROW === */
.ec-row{margin-top:14px}

/* === EXTRA PREVIEW BUTTONS (Copy / Share / Print) === */
.btn-dl-copy,.btn-dl-share,.btn-dl-print{background:#F3F4F6;color:#374151;border:1.5px solid #E5E7EB}
.btn-dl-copy:hover,.btn-dl-share:hover,.btn-dl-print:hover{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}

/* Logo remove button */
.btn-logo-remove{padding:7px 10px;border:1.5px solid #FECACA;border-radius:8px;background:#FEF2F2;font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:700;color:#DC2626;cursor:pointer;transition:all .15s}
.btn-logo-remove:hover{background:#FEE2E2}

/* === FIELD HINT === */
.field-hint{font-size:.78rem;color:#9CA3AF;margin-top:5px;line-height:1.45}

/* === SCANNER — PASTE BAR === */
.paste-bar{display:flex;align-items:center;gap:12px;margin-top:14px}
.btn-paste{padding:8px 18px;border:1.5px solid #E5E7EB;border-radius:9px;background:#fff;font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:700;color:#374151;cursor:pointer;transition:all .15s}
.btn-paste:hover{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}
.paste-hint{font-size:.8rem;color:#9CA3AF}

/* === SCANNER — SHARE RESULT BUTTON === */
.btn-share-result{padding:7px 16px;border-radius:8px;font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .15s;border:1.5px solid #E5E7EB;background:#fff;color:#374151}
.btn-share-result:hover{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}

/* === SCAN HISTORY === */
.scan-history-section{background:#fff;border-radius:16px;border:1.5px solid #E5E7EB;padding:24px;margin-top:20px}
.scan-history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.scan-history-header h3{font-size:.95rem;font-weight:700;color:#111827}
.btn-clear-history{padding:5px 12px;border:1.5px solid #FECACA;border-radius:7px;background:#FEF2F2;font-family:'Outfit',sans-serif;font-size:.78rem;font-weight:700;color:#DC2626;cursor:pointer;transition:all .15s}
.btn-clear-history:hover{background:#FEE2E2}
.scan-history-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.history-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:#F9FAFB;border-radius:10px;border:1.5px solid #F3F4F6}
.history-text{flex:1;min-width:0;font-size:.875rem;color:#111827;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.history-date{font-size:.75rem;color:#9CA3AF;flex-shrink:0;white-space:nowrap}
.history-actions{display:flex;gap:6px;flex-shrink:0}
.history-copy,.history-open{padding:4px 10px;border-radius:6px;font-family:'Outfit',sans-serif;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .15s;border:none;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;line-height:1}
.history-copy{background:#4f46e5;color:#fff}
.history-copy:hover{background:#4338ca}
.history-open{background:#F3F4F6;color:#374151}
.history-open:hover{background:#E5E7EB}

/* === UTILS === */
.container{max-width:1140px;margin:0 auto;padding:0 24px}
@media(max-width:900px){
  .type-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .type-tabs::-webkit-scrollbar{display:none}
  .type-tab{white-space:nowrap;flex-shrink:0}
}
@media(max-width:640px){
  .home-hero h1{font-size:1.8rem}
  .generator-layout{padding:20px 16px}
  .form-panel,.preview-card{padding:20px}
  .dl-btns{flex-wrap:wrap}
  .btn-dl{flex:1 1 calc(50% - 4px);min-width:0}
  .field-row{grid-template-columns:1fr}
  /* mobile header handled by style.css */
  .dot-style-btns,.ec-btns{flex-wrap:nowrap;overflow-x:auto}
  .dot-btn,.ec-btn{flex-shrink:0}
  .history-item{flex-wrap:wrap}
  .history-date{display:none}
}

/* === BLOG === */
.blog-article{min-height:80vh}
.blog-hero-wrap{width:100%;height:420px;overflow:hidden;background:#E5E7EB}
.blog-hero-img{width:100%;height:100%;object-fit:cover;display:block}
.blog-container{max-width:780px;margin:0 auto;padding:40px 24px 64px}
.blog-back{display:inline-flex;align-items:center;gap:5px;color:#6B7280;text-decoration:none;font-size:.875rem;font-weight:600;margin-bottom:20px;transition:color .15s}
.blog-back:hover{color:#4f46e5}
.blog-meta{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.blog-date{font-size:.82rem;color:#9CA3AF}
.blog-tag{background:#eef2ff;color:#4f46e5;padding:3px 11px;border-radius:20px;font-weight:700;font-size:.75rem;letter-spacing:.03em}
.blog-container h1{font-size:2rem;font-weight:800;color:#111827;line-height:1.25;margin-bottom:24px}
.blog-content p{color:#374151;line-height:1.8;margin-bottom:20px;font-size:.975rem}
.blog-content h2{font-size:1.3rem;font-weight:800;color:#111827;margin:36px 0 12px;line-height:1.3}
.blog-content h3{font-size:1.05rem;font-weight:700;color:#111827;margin:24px 0 8px}
.blog-content ul,.blog-content ol{margin:12px 0 20px 24px;color:#374151;line-height:1.8}
.blog-content li{margin-bottom:8px;font-size:.975rem}
.blog-content strong{color:#111827;font-weight:700}
.blog-img-wrap{margin:32px 0;border-radius:16px;background:#F1F5F9;padding:20px;text-align:center}
.blog-img{max-width:100%;max-height:420px;width:auto;height:auto;object-fit:contain;border-radius:10px;box-shadow:0 4px 24px rgba(0,0,0,.1);display:block;margin:0 auto}
.blog-img-caption{text-align:center;font-size:.75rem;color:#9CA3AF;margin-top:12px;font-style:italic}
.blog-tip{background:#f5f3ff;border-left:4px solid #4f46e5;border-radius:0 12px 12px 0;padding:16px 20px;margin:24px 0}
.blog-tip p{margin-bottom:0;color:#3730a3;font-size:.9rem}
.blog-cta{background:linear-gradient(135deg,#eef2ff,#a5b4fc);border-radius:16px;padding:36px 32px;margin:44px 0 0;text-align:center}
.blog-cta h3{font-size:1.2rem;font-weight:800;color:#4f46e5;margin-bottom:10px}
.blog-cta p{color:#374151;margin-bottom:20px}
.blog-cta-btn{display:inline-block;background:#4f46e5;color:#fff;padding:13px 32px;border-radius:10px;font-weight:700;text-decoration:none;font-size:.95rem;transition:background .15s}
.blog-cta-btn:hover{background:#4338ca}
/* Blog index */
.blog-index{max-width:1000px;margin:0 auto;padding:48px 24px}
.blog-index-h1{font-size:2rem;font-weight:800;color:#111827;margin-bottom:8px}
.blog-index-sub{color:#6B7280;margin-bottom:40px;font-size:1rem}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:28px}
.blog-card{background:#fff;border-radius:16px;border:1.5px solid #E5E7EB;overflow:hidden;text-decoration:none;display:flex;flex-direction:column;transition:box-shadow .2s,transform .15s}
.blog-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.1);transform:translateY(-2px)}
.blog-card-img{width:100%;height:180px;object-fit:cover;display:block}
.blog-card-body{padding:20px;flex:1;display:flex;flex-direction:column}
.blog-card-tag{font-size:.72rem;font-weight:700;color:#4f46e5;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.blog-card-title{font-size:1rem;font-weight:800;color:#111827;margin-bottom:8px;line-height:1.35}
.blog-card-desc{font-size:.85rem;color:#6B7280;line-height:1.6;flex:1;margin-bottom:14px}
.blog-card-date{font-size:.75rem;color:#9CA3AF}
@media(max-width:640px){
  .blog-hero-wrap{height:240px}
  .blog-container h1{font-size:1.5rem}
  .blog-img{height:220px}
  .blog-cta{padding:24px 20px}
  .blog-grid{grid-template-columns:1fr}
}

/* === COLOR PRESETS === */
.presets-list{display:flex;gap:7px;margin-top:10px;flex-wrap:wrap}
.preset-swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .15s,border-color .15s;flex-shrink:0}
.preset-swatch:hover{transform:scale(1.15)}
.preset-swatch.active{border-color:#4f46e5;box-shadow:0 0 0 2px #a5b4fc}

/* === TRANSPARENT BG TOGGLE === */
.toggle-row{margin-top:12px}
.toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:.85rem;font-weight:600;color:#374151;user-select:none}
.toggle-track{position:relative;display:inline-flex;align-items:center;flex-shrink:0}
.toggle-track input[type=checkbox]{opacity:0;width:0;height:0;position:absolute}
.toggle-thumb{display:block;width:38px;height:22px;background:#D1D5DB;border-radius:11px;position:relative;transition:background .2s}
.toggle-thumb::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle-track input:checked ~ .toggle-thumb{background:#4f46e5}
.toggle-track input:checked ~ .toggle-thumb::after{left:19px}

/* === FRAME SELECTOR === */
.frame-row{margin-top:14px}
.frame-row > label{display:block;font-size:.78rem;font-weight:700;color:#6B7280;text-transform:uppercase;letter-spacing:.04em;margin-bottom:7px}
.frame-btns{display:flex;gap:7px}
.frame-btn{flex:1;padding:7px 4px;font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:700;border:1.5px solid #E5E7EB;border-radius:9px;background:#fff;color:#6B7280;cursor:pointer;transition:all .15s;text-align:center}
.frame-btn:hover{border-color:#4f46e5;color:#4f46e5}
.frame-btn.active{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}
.frame-text-input{margin-top:8px;width:100%;box-sizing:border-box;padding:8px 12px;border:1.5px solid #E5E7EB;border-radius:9px;font-family:'Outfit',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;outline:none;transition:border-color .15s}
.frame-text-input:focus{border-color:#4f46e5}

/* === QR CONTENT DISPLAY === */
.qr-content{display:flex;align-items:baseline;gap:6px;margin-top:10px;padding:8px 12px;background:#F9FAFB;border:1px solid #E5E7EB;border-radius:10px;overflow:hidden}
.qr-content-label{font-size:.72rem;font-weight:700;color:#6B7280;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;flex-shrink:0}
.qr-content-text{font-size:.8rem;color:#374151;font-family:monospace;word-break:break-all;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
