/* ===== Dashboard styles ===== */
.dash-body{background:#f5f5f7;min-height:100vh;display:flex;flex-direction:column}
.dash-main{flex:1;max-width:1180px;margin:0 auto;padding:32px 24px;width:100%}
.dash-nav{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.dash-nav-inner{max-width:1180px;margin:0 auto;padding:14px 24px;display:flex;justify-content:space-between;align-items:center}
.dash-menu{display:flex;gap:4px;background:var(--cream);padding:4px;border-radius:99px}
.dash-menu a{padding:8px 18px;border-radius:99px;font-size:13px;font-weight:700;color:var(--charcoal);transition:.2s}
.dash-menu a:hover{color:var(--black)}
.dash-menu a.active{background:var(--black);color:var(--chartreuse)}
.dash-user{display:flex;align-items:center;gap:14px}
.dash-biz{text-align:end;line-height:1.3}
.dash-biz .biz-name{font-weight:800;font-size:14px;color:var(--black)}
.dash-biz .biz-user{font-size:11px;color:var(--charcoal);font-family:monospace}
.btn-icon{width:38px;height:38px;border-radius:50%;background:var(--cream);border:1px solid var(--line);display:grid;place-items:center;font-size:18px;color:var(--charcoal);transition:.2s}
.btn-icon:hover{background:var(--black);color:#fff;border-color:var(--black)}

/* Top section */
.dash-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px;flex-wrap:wrap;gap:14px}
.dash-head h1{font-size:28px;font-weight:900;letter-spacing:-.02em;margin-bottom:4px}
.dash-head p{color:var(--charcoal);font-size:14px}

.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:30px}
.dash-stat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 22px;position:relative;overflow:hidden}
.dash-stat::before{content:"";position:absolute;inset-inline-start:0;top:0;bottom:0;width:4px;background:var(--chartreuse)}
.dash-stat .v{font-family:'Montserrat',sans-serif;font-size:30px;font-weight:900;letter-spacing:-.02em;line-height:1}
.dash-stat .l{font-size:12px;color:var(--charcoal);margin-top:6px;font-weight:600;letter-spacing:.02em}
.dash-stat.accent{background:var(--black);color:#fff;border-color:var(--black)}
.dash-stat.accent::before{background:var(--chartreuse)}
.dash-stat.accent .l{color:rgba(255,255,255,.6)}
.dash-stat.accent .v{color:var(--chartreuse)}

/* QR list */
.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.qr-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;transition:.3s var(--ease);position:relative;overflow:hidden}
.qr-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--chartreuse)}
.qr-card .type-tag{position:absolute;top:14px;inset-inline-end:14px;background:var(--cream);color:var(--charcoal);font-size:10px;font-weight:700;padding:4px 10px;border-radius:99px;text-transform:uppercase;letter-spacing:.05em}
.qr-card .qr-thumb{width:120px;height:120px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;margin:0 auto 16px;display:block}
.qr-card .qr-thumb img{width:100%;height:100%;display:block}
.qr-card h3{font-size:16px;font-weight:800;margin-bottom:4px;text-align:center}
.qr-card .desc{font-size:12px;color:var(--charcoal);text-align:center;margin-bottom:14px;min-height:30px;line-height:1.5}
.qr-card .qr-meta{display:flex;justify-content:space-around;padding:12px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:12px;font-size:12px;color:var(--charcoal)}
.qr-card .qr-meta b{display:block;color:var(--black);font-size:15px;font-weight:800;font-family:'Montserrat',sans-serif}
.qr-card .qr-actions{display:flex;gap:6px;flex-wrap:wrap}
.qr-card .qr-actions a{flex:1;text-align:center;padding:9px;border-radius:10px;font-size:12px;font-weight:700;background:var(--cream);color:var(--black);transition:.2s;border:1px solid transparent}
.qr-card .qr-actions a:hover{background:var(--black);color:#fff}
.qr-card .qr-actions a.danger:hover{background:#dc2626;color:#fff}
.qr-card .featured-tag{position:absolute;top:14px;inset-inline-start:14px;background:var(--gold,#f5c451);color:#3d2c00;font-size:10px;font-weight:800;padding:4px 10px;border-radius:99px}
.filter-bar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:24px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 18px}
.filter-row{display:flex;gap:8px;flex-wrap:wrap}
.filter-row input,.filter-row select{background:var(--cream);border:1px solid transparent;padding:10px 14px;border-radius:10px;font-family:inherit;font-size:14px;transition:.2s}
.filter-row input:focus,.filter-row select:focus{outline:none;border-color:var(--chartreuse);background:#fff}
.qr-card.empty{background:transparent;border:2px dashed var(--line-strong);display:grid;place-items:center;text-align:center;min-height:300px;padding:40px}
.qr-card.empty .em{font-size:48px;margin-bottom:14px;opacity:.5}
.qr-card.empty h3{font-size:18px;margin-bottom:8px}
.qr-card.empty p{font-size:13px;color:var(--charcoal);margin-bottom:18px}

/* Forms */
.dash-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px;max-width:720px;margin:0 auto}
.dash-card h2{font-size:22px;margin-bottom:6px}
.dash-card .crumb{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--charcoal);margin-bottom:18px}
.dash-card .crumb a{color:var(--black);font-weight:600}

/* Auth */
.auth-grid{min-height:80vh;display:grid;place-items:center;padding:30px 16px}
.auth-card-c{background:#fff;border:1px solid var(--line);border-radius:24px;padding:42px;width:100%;max-width:440px;box-shadow:var(--shadow)}
.auth-card-c .ic{width:54px;height:54px;border-radius:14px;background:var(--chartreuse);display:grid;place-items:center;font-size:24px;margin:0 auto 20px}
.auth-card-c h2{text-align:center;font-size:24px;margin-bottom:8px}
.auth-card-c p{text-align:center;color:var(--charcoal);margin-bottom:26px;font-size:14px}

/* QR detail (view + share) */
.qr-detail{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:start}
.qr-big{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;text-align:center}
.qr-big img{width:260px;height:260px;display:block}
.qr-big .url-box{margin-top:14px;background:var(--cream);padding:8px 12px;border-radius:8px;font-family:monospace;font-size:11px;color:var(--charcoal);word-break:break-all;direction:ltr;text-align:center}
.qr-info{flex:1}
.qr-info h2{margin-bottom:8px}
.qr-info .pill{display:inline-block;background:var(--cream);padding:4px 10px;border-radius:99px;font-size:11px;font-weight:700;color:var(--charcoal);margin-inline-end:6px}
.qr-info p{color:var(--charcoal);margin:14px 0}
.share-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.share-row a{padding:10px 16px;border-radius:10px;font-weight:700;font-size:13px;background:var(--cream);color:var(--black);transition:.2s}
.share-row a:hover{background:var(--black);color:#fff}

/* Flash */
.flash{background:var(--chartreuse-soft);border:1px solid var(--chartreuse);color:var(--black);padding:14px 18px;border-radius:12px;margin-bottom:20px;font-weight:600;display:flex;align-items:center;gap:10px}
.flash.error{background:#fee;border-color:#fcc;color:#c33}

/* Empty state */
.empty-state{text-align:center;padding:60px 20px}
.empty-state .em{font-size:64px;margin-bottom:20px;opacity:.5}
.empty-state h2{font-size:22px;margin-bottom:10px}
.empty-state p{color:var(--charcoal);margin-bottom:24px;font-size:14px}

/* ===== Editor layout (2 columns with sticky preview) ===== */
.editor-layout{display:grid;grid-template-columns:1fr 380px;gap:20px;align-items:start}
.editor-main{min-width:0}
.editor-aside{position:sticky;top:96px}
.preview-card{padding:18px}
.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.preview-header h3{font-size:15px;margin:0}
.save-status{font-size:11px;color:var(--charcoal);font-weight:700;letter-spacing:.04em;padding:4px 10px;border-radius:99px;background:var(--cream)}
.save-status.saving{background:#fef3c7;color:#92400e}
.save-status.saved{background:var(--chartreuse-soft);color:#101010}
.save-status.error{background:#fee;color:#c33}

/* Phone shell with iframe live preview */
.phone-shell{position:relative;background:#101010;border-radius:32px;padding:10px;margin:0 auto;width:280px;height:540px;box-shadow:0 20px 50px rgba(0,0,0,.18)}
.phone-notch{position:absolute;top:10px;inset-inline:50%;transform:translateX(-50%);width:80px;height:18px;background:#101010;border-radius:0 0 12px 12px;z-index:2}
.phone-shell iframe{width:100%;height:100%;border:0;border-radius:22px;background:#fff;display:block}

#qrBox{text-align:center;margin:8px 0 4px}
#qrBox canvas{display:inline-block}
.qr-link-box{display:flex;gap:6px;background:var(--cream);padding:6px;border-radius:10px;margin-top:10px}
.qr-link-box input{flex:1;background:transparent;border:none;font-family:monospace;font-size:11px;color:var(--charcoal);padding:6px 10px;min-width:0}
.qr-link-box input:focus{outline:none}
.btn-mini{background:#fff;border:1px solid var(--line);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:14px;transition:.2s}
.btn-mini:hover{background:var(--black);color:#fff;border-color:var(--black)}
.qr-actions-row{display:flex;gap:8px;margin-top:12px}
.qr-actions-row .btn{flex:1;justify-content:center;font-size:12px;padding:10px}

.editor-card{max-width:100%}
.sub-h{margin:18px 0 10px;color:var(--charcoal);font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:800;border-bottom:1px solid var(--line);padding-bottom:6px}
.form-row.qr-3col{grid-template-columns:repeat(3,1fr)}
@media(max-width:1080px){
  .editor-layout{grid-template-columns:1fr}
  .editor-aside{position:static}
  .phone-shell{margin:0 auto}
  .form-row.qr-3col{grid-template-columns:1fr 1fr}
}
.form-section-block:first-of-type{padding-top:0}
.form-section-block{padding:24px 0;border-bottom:1px solid var(--line)}
.form-section-block:last-of-type{border-bottom:none}
.form-section-block h3{font-size:18px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.type-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.type-tile{background:var(--cream);border:2px solid transparent;padding:18px 14px;border-radius:14px;cursor:pointer;text-align:center;font-size:14px;font-weight:700;transition:.2s;display:block}
.type-tile:hover{background:#fff;border-color:var(--line-strong)}
.type-tile input{display:none}
.type-tile:has(input:checked){background:var(--black);color:#fff;border-color:var(--chartreuse)}
.checkbox-tile{display:flex;align-items:center;gap:14px;background:var(--cream);padding:14px 18px;border-radius:12px;cursor:pointer;border:2px solid transparent;transition:.2s}
.checkbox-tile:hover{background:#fff}
.checkbox-tile:has(input:checked){background:#fff;border-color:var(--chartreuse)}
.checkbox-tile input{width:20px;height:20px;accent-color:var(--chartreuse)}
.checkbox-tile div{flex:1;line-height:1.3}
.checkbox-tile small{display:block;color:var(--charcoal);font-weight:400;font-size:12px;margin-top:2px}

/* Dropzone */
.dropzone-form{margin-bottom:18px}
.dropzone{background:var(--cream);border:2px dashed var(--line-strong);border-radius:16px;padding:36px 20px;text-align:center;cursor:pointer;transition:.2s}
.dropzone:hover,.dropzone.drag{background:#fff;border-color:var(--chartreuse)}
.dropzone .dz-icon{font-size:42px;margin-bottom:10px;opacity:.7}
.dropzone p{font-weight:600;margin-bottom:6px}
.dropzone small{color:var(--charcoal);font-size:12px}

/* Thumbs */
.thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-top:14px}
.thumb{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--line);cursor:grab}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb .order{position:absolute;top:6px;inset-inline-start:6px;background:rgba(0,0,0,.7);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px}
.thumb .del{position:absolute;top:6px;inset-inline-end:6px;background:#fff;color:#dc2626;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:12px;text-decoration:none;opacity:0;transition:.2s}
.thumb:hover .del{opacity:1}

/* PDF file */
.file-current{background:var(--cream);padding:14px 18px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:14px}
.btn-sm{padding:6px 14px;border-radius:8px;font-size:12px;font-weight:700;text-decoration:none}
.btn-sm.danger{background:#fee;color:#c33}
.btn-sm.danger:hover{background:#c33;color:#fff}
.btn-sm-c{padding:10px 22px;font-size:13px}
.upload-form{display:flex;gap:10px;align-items:center;background:var(--cream);padding:14px;border-radius:12px}
.upload-form input[type=file]{flex:1;font-family:inherit;font-size:13px}

/* Links list */
.links-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.link-row{display:flex;align-items:center;gap:12px;background:var(--cream);border:1px solid transparent;padding:12px 14px;border-radius:12px}
.link-row:hover{border-color:var(--line)}
.link-row .drag-handle{cursor:grab;color:#aaa;font-weight:900;letter-spacing:-2px}
.link-row .link-ic{font-size:24px}
.link-row .link-meta{flex:1;line-height:1.3}
.link-row .link-meta small{display:block;color:var(--charcoal);font-size:11px;direction:ltr;text-align:start}
.link-row .del{color:#dc2626;font-weight:700;text-decoration:none;padding:4px 10px}
.link-add-row{display:flex;gap:8px;background:#fff;border:1px dashed var(--line-strong);padding:12px;border-radius:12px}
.link-add-row input{background:var(--cream);border:none;padding:10px 14px;border-radius:8px;font-family:inherit;font-size:13px;flex:1}
.link-add-row input:focus{outline:2px solid var(--chartreuse)}

/* QR style */
.qr-style-grid{display:grid;grid-template-columns:1fr 280px;gap:30px;align-items:start}
.qr-controls .form-row .field input[type=color]{width:100%;height:46px;padding:4px;border-radius:10px;cursor:pointer}
.qr-preview-box{text-align:center}
.qr-canvas-frame{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;display:inline-block}
.qr-canvas-frame img{width:240px;height:240px;display:block}
.qr-preview-box small{margin-top:10px;display:block}

/* Actions */
.actions-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px;padding-top:24px;border-top:1px solid var(--line)}

/* Quick stats inside view */
.quick-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px}
.quick-stats div{background:var(--cream);padding:14px;border-radius:12px;text-align:center}
.quick-stats b{display:block;font-family:'Montserrat',sans-serif;font-size:22px;font-weight:900;color:var(--black);line-height:1}
.quick-stats span{font-size:11px;color:var(--charcoal);margin-top:4px;display:block}

/* Mini chart */
.mini-chart{display:flex;align-items:flex-end;gap:10px;padding:18px 0;height:220px;overflow-x:auto}
.bar-col{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:50px}
.bar{width:30px;background:linear-gradient(180deg,var(--chartreuse),var(--chartreuse-deep));border-radius:6px 6px 0 0;transition:.3s}
.bar-l{font-size:11px;font-weight:700;color:var(--black)}
.bar-d{font-size:10px;color:var(--charcoal)}

/* Analytics grid */
.analytics-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-top:18px}
@media(max-width:880px){.analytics-grid{grid-template-columns:1fr}}
.event-list{display:flex;flex-direction:column;gap:8px}
.event-row{display:flex;align-items:center;gap:12px;background:var(--cream);padding:12px 14px;border-radius:10px}
.event-row .ic{font-size:22px}
.event-row .lbl{flex:1;font-weight:600;font-size:13px}
.event-row strong{font-family:'Montserrat',sans-serif;font-weight:900;font-size:16px}

.dash-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}
.dash-table th{text-align:start;padding:10px 14px;font-size:11px;color:var(--charcoal);background:var(--cream);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.dash-table td{padding:14px;border-bottom:1px solid var(--line)}
.dash-table tr:last-child td{border-bottom:none}
.dash-table tr:hover td{background:var(--cream)}

/* Profile info */
.acct-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px 20px;background:var(--cream);padding:18px;border-radius:12px;font-size:14px}
.acct-info b{display:block;color:var(--charcoal);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}

@media(max-width:720px){
  .qr-detail{grid-template-columns:1fr}
  .qr-big img{width:200px;height:200px}
  .dash-card{padding:24px 20px}
  .qr-style-grid{grid-template-columns:1fr}
  .dash-menu{display:none}
}
