/* ═══ PAGES.CSS — Extended Styles ═══ */

/* ── AUTH PAGES ── */
.auth-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--bg)}
.auth-left{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg2);padding:48px}
.auth-left canvas#authBrush{position:relative;z-index:2;max-width:280px;width:100%;height:auto}
.auth-left-content{position:absolute;bottom:48px;left:48px;right:48px;z-index:3;text-align:center}
.auth-left-content h2{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2rem);color:var(--ivory);line-height:1.2;margin-bottom:10px}
.auth-left-content h2 em{font-style:italic;color:var(--gold)}
.auth-left-content p{color:var(--muted);font-size:.9rem;line-height:1.6}
.auth-right{display:flex;align-items:center;justify-content:center;padding:48px 32px;background:var(--bg);overflow-y:auto}
.auth-box{width:100%;max-width:420px}
.logo-wrap{display:flex;align-items:center;gap:10px;margin-bottom:28px}
.logo-wrap .logo-text{font-family:var(--display);font-size:1.15rem;font-weight:600;color:var(--ivory);letter-spacing:.04em}
.auth-box h2{font-family:var(--serif);font-size:2rem;color:var(--ivory);margin-bottom:8px;font-weight:500}
.auth-sub{color:var(--muted);font-size:.88rem;margin-bottom:28px;line-height:1.5}
.social-btns{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.social-auth-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-family:var(--sans);font-size:.82rem;cursor:none;transition:all .3s}
.social-auth-btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold);background:rgba(201,169,110,.04)}
.social-auth-btn:disabled{opacity:.5;cursor:not-allowed}
.auth-divider{display:flex;align-items:center;gap:14px;margin:24px 0;color:var(--muted);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-btn{width:100%;padding:15px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));border:none;border-radius:var(--radius-sm);color:var(--bg);font-family:var(--sans);font-weight:600;font-size:.9rem;cursor:none;transition:all .3s;letter-spacing:.03em}
.auth-btn:hover:not(:disabled){box-shadow:0 8px 30px var(--gold-glow);transform:translateY(-1px)}
.auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.auth-footer-link{text-align:center;margin-top:24px;font-size:.85rem;color:var(--muted)}
.auth-footer-link a{color:var(--gold);text-decoration:none;font-weight:500}
.auth-footer-link a:hover{text-decoration:underline;text-underline-offset:3px}
.auth-error{display:none;background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-sm);padding:12px 14px;color:#fca5a5;font-size:.82rem;margin-bottom:18px;line-height:1.5}
.auth-error.visible{display:block}
.auth-success{display:none;background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.25);border-radius:var(--radius-sm);padding:12px 14px;color:#86efac;font-size:.82rem;margin-bottom:18px;line-height:1.5}
.auth-success.visible{display:block}
.account-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.type-card{padding:16px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:none;transition:all .3s;background:var(--bg3);text-align:center}
.type-card:hover{border-color:var(--border-hover)}
.type-card.selected{border-color:var(--gold);background:rgba(201,169,110,.06);box-shadow:0 0 0 1px rgba(201,169,110,.15)}
.type-icon{font-size:1.6rem;margin-bottom:8px}
.type-label{font-size:.78rem;color:var(--muted);line-height:1.4}
.type-label strong{display:block;color:var(--ivory);font-size:.85rem;margin-bottom:2px}
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:500}
.form-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px 16px;color:var(--ivory);font-family:var(--sans);font-size:.88rem;outline:none;transition:all .3s;cursor:none}
.form-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,110,.08)}
.form-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px 16px;color:var(--ivory);font-family:var(--sans);font-size:.88rem;outline:none;resize:vertical;transition:all .3s;min-height:80px}
.form-textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,110,.08)}
.auth-config-banner{display:none;background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.25);border-radius:var(--radius-sm);padding:12px 14px;color:#fcd34d;font-size:.78rem;margin-bottom:18px;line-height:1.5}
.auth-config-banner.visible{display:block}
@media(max-width:900px){.auth-page{grid-template-columns:1fr}.auth-left{display:none}.auth-right{padding:40px 24px;min-height:100vh}}

/* ── PROFILE BANNER ── */
.profile-banner{position:relative;min-height:340px;padding:140px 48px 48px;display:flex;align-items:flex-end;gap:40px;flex-wrap:wrap;overflow:hidden;background:var(--bg2)}
.profile-banner canvas{position:absolute;inset:0;width:100%;height:100%}
.profile-banner-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg),transparent 70%)}
.profile-info{display:flex;align-items:flex-end;gap:24px;position:relative;z-index:1;flex:1}
.profile-avatar{width:100px;height:100px;border-radius:50%;border:3px solid var(--gold);overflow:hidden;flex-shrink:0}
.profile-avatar canvas{width:100%;height:100%}
.profile-meta{flex:1}
.profile-meta h1{font-family:var(--serif);font-size:2.2rem;color:var(--ivory);margin-bottom:6px}
.profile-meta p{color:var(--muted);font-size:.88rem;margin-bottom:16px}
.profile-stats-row{display:flex;gap:28px}
.p-stat{text-align:center}
.p-stat-num{font-family:var(--display);font-size:1.1rem;color:var(--gold);font-weight:600}
.p-stat-label{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.profile-actions{display:flex;gap:12px;align-items:flex-end;position:relative;z-index:1}

/* ── PROFILE BODY ── */
.profile-body{display:grid;grid-template-columns:2fr 1fr;gap:40px;padding:48px;max-width:1400px;margin:0 auto}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.portfolio-item{border-radius:var(--radius-sm);overflow:hidden;cursor:none;position:relative;aspect-ratio:1}
.portfolio-item canvas{width:100%;height:100%}
.portfolio-overlay{position:absolute;inset:0;background:rgba(0,0,0,.6);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center}
.portfolio-item:hover .portfolio-overlay{opacity:1}
.view-icon{font-size:1.4rem}
.pricing-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:16px}
.pricing-card h3{font-family:var(--serif);font-size:1rem;color:var(--ivory);margin-bottom:20px}
.price-tier{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.tier-name{font-size:.85rem;color:var(--text)}
.tier-price{font-family:var(--display);font-size:.85rem;color:var(--gold);font-weight:600}
.book-btn{width:100%;margin-top:20px;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));border:none;border-radius:var(--radius-sm);color:var(--bg);font-family:var(--sans);font-weight:600;font-size:.88rem;cursor:none;transition:all .3s}
.book-btn:hover{box-shadow:0 8px 30px var(--gold-glow)}

/* ── LIGHTBOX ── */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.9);backdrop-filter:blur(20px);z-index:10000;display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox-inner{position:relative;max-width:90vw;max-height:90vh}
.lightbox-close{position:absolute;top:-40px;right:0;background:none;border:none;color:var(--gold);font-size:1.4rem;cursor:none}

/* ── ORDER PAGE ── */
.order-page{min-height:100vh;padding:120px 0 60px;background:var(--bg)}
.order-container{max-width:720px;margin:0 auto;padding:0 24px}
.order-header{text-align:center;margin-bottom:48px}
.progress-bar{display:flex;justify-content:space-between;margin-bottom:48px;position:relative}
.progress-bar::before{content:'';position:absolute;top:16px;left:5%;right:5%;height:1px;background:var(--border)}
.progress-step{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;z-index:1}
.step-circle{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--muted);background:var(--bg);transition:all .4s var(--ease);font-family:var(--display);font-weight:600}
.progress-step.active .step-circle{border-color:var(--gold);color:var(--bg);background:var(--gold);box-shadow:0 0 20px var(--gold-glow)}
.progress-step.done .step-circle{border-color:var(--gold);color:var(--gold);background:transparent}
.step-title{font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.progress-step.active .step-title{color:var(--gold)}
.order-step{display:none}
.order-step.active{display:block;animation:fadeUp .5s var(--ease)}
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:48px;text-align:center;cursor:none;transition:all .3s}
.upload-zone:hover{border-color:var(--gold);background:rgba(201,169,110,.03)}
.upload-icon{font-size:2rem;margin-bottom:12px}
.upload-text{color:var(--ivory);font-size:.95rem;margin-bottom:4px}
.upload-sub{color:var(--muted);font-size:.75rem}
.style-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}
.style-option{border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px;text-align:center;cursor:none;transition:all .4s var(--ease)}
.style-option:hover{border-color:var(--border-hover)}
.style-option.selected{border-color:var(--gold);background:rgba(201,169,110,.06);box-shadow:0 0 20px rgba(201,169,110,.08)}
.style-icon{font-size:1.4rem;margin-bottom:8px}
.style-name{font-size:.78rem;color:var(--ivory)}
.size-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.size-option{border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px;text-align:center;cursor:none;transition:all .4s var(--ease)}
.size-option.selected{border-color:var(--gold);background:rgba(201,169,110,.06)}
.size-dims{font-family:var(--display);font-size:1.3rem;color:var(--ivory);font-weight:700}
.size-price{color:var(--gold);font-size:.82rem;font-weight:600}
.delivery-options{display:flex;flex-direction:column;gap:12px}
.delivery-opt{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px;cursor:none;transition:all .4s var(--ease)}
.delivery-opt.selected{border-color:var(--gold);background:rgba(201,169,110,.06)}
.delivery-name{font-family:var(--serif);color:var(--ivory);font-size:1rem;margin-bottom:4px}
.delivery-time{font-size:.78rem;color:var(--muted)}
.delivery-price{font-family:var(--display);color:var(--gold);font-weight:600}
.order-summary{border:1px solid var(--border);border-radius:var(--radius);padding:28px;margin-bottom:28px;background:var(--bg3)}
.order-summary h3{font-family:var(--serif);color:var(--ivory);font-size:1.1rem;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.summary-row{display:flex;justify-content:space-between;padding:10px 0;font-size:.85rem;color:var(--text)}
.summary-row:last-child{border-top:1px solid var(--border);padding-top:16px;margin-top:8px}
.step-nav{display:flex;justify-content:space-between;margin-top:32px}
.step-btn-next{padding:14px 32px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));border:none;border-radius:var(--radius-pill);color:var(--bg);font-weight:600;font-size:.88rem;cursor:none;transition:all .3s;font-family:var(--sans)}
.step-btn-next:hover{box-shadow:0 6px 24px var(--gold-glow)}
.step-btn-prev{padding:14px 24px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--muted);font-size:.85rem;cursor:none;transition:all .3s;font-family:var(--sans)}
.step-btn-prev:hover{border-color:var(--gold);color:var(--gold)}

/* ── DASHBOARD ── */
.dashboard{display:grid;grid-template-columns:260px 1fr;min-height:100vh;padding-top:72px}
.dash-sidebar{background:var(--bg2);border-right:1px solid var(--border);padding:32px 0;position:sticky;top:72px;height:calc(100vh - 72px);overflow-y:auto}
.dash-nav-item{display:flex;align-items:center;gap:12px;padding:12px 28px;font-size:.85rem;color:var(--muted);cursor:none;transition:all .3s;border-left:2px solid transparent}
.dash-nav-item:hover{color:var(--text);background:var(--surface)}
.dash-nav-item.active{color:var(--gold);border-left-color:var(--gold);background:rgba(201,169,110,.04)}
.dash-main{padding:40px;overflow-y:auto}
.dash-tab{display:block}
.dash-header{margin-bottom:36px}
.dash-header h1{font-family:var(--serif);font-size:2rem;color:var(--ivory);margin-bottom:8px}
.dash-header p{color:var(--muted);font-size:.88rem}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}
.stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .4s var(--ease)}
.stat-card:hover{border-color:var(--border-hover);transform:translateY(-3px)}
.s-label{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.s-val{font-family:var(--display);font-size:1.8rem;color:var(--ivory);font-weight:700}
.s-change{font-size:.72rem;color:var(--gold);margin-top:6px}
.dash-section{margin-bottom:36px}
.dash-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.dash-section-header h2{font-family:var(--serif);font-size:1.2rem;color:var(--ivory)}
.orders-table{width:100%;border-collapse:collapse;font-size:.85rem}
.orders-table thead{border-bottom:1px solid var(--border)}
.orders-table th{text-align:left;padding:12px 16px;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:500}
.orders-table td{padding:14px 16px;color:var(--text);border-bottom:1px solid rgba(201,169,110,.06)}
.orders-table tr:hover td{background:var(--surface)}
.order-badge{padding:4px 12px;border-radius:var(--radius-pill);font-size:.68rem;font-weight:600;letter-spacing:.04em}
.badge-active{background:rgba(201,169,110,.12);color:var(--gold)}
.badge-pending{background:rgba(250,204,21,.1);color:#facc15}
.badge-done{background:rgba(74,222,128,.1);color:#4ade80}

/* ── EXPLORE PAGE ── */
.explore-page{padding:120px 0 60px;background:var(--bg);min-height:100vh}
.search-bar{display:flex;gap:12px;margin-bottom:32px}
.search-bar input{flex:1}
.filter-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px}

/* ── GALLERY PAGE ── */
.gallery-page{min-height:100vh;background:var(--bg);padding:120px 0 60px}
.gallery-room{position:relative;max-width:1400px;margin:0 auto;padding:0 48px}
.gallery-wall{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.gallery-frame{position:relative;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;cursor:none;transition:all .5s var(--ease)}
.gallery-frame:hover{border-color:var(--border-hover);box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 40px rgba(201,169,110,.06);transform:translateY(-8px)}
.gallery-frame canvas{width:100%;height:100%}
.gallery-label{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(to top,rgba(5,5,5,.9),transparent);transform:translateY(100%);transition:transform .4s var(--ease)}
.gallery-frame:hover .gallery-label{transform:translateY(0)}
.gallery-label h4{font-family:var(--serif);color:var(--ivory);font-size:.95rem;margin-bottom:4px}
.gallery-label p{font-size:.72rem;color:var(--muted)}

/* ── ABOUT PAGE ── */
.about-page-hero{position:relative;min-height:60vh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center;padding:140px 48px 80px}
.about-page-hero canvas{position:absolute;inset:0;width:100%;height:100%}
.about-page-hero .hero-content{position:relative;z-index:2}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:0 auto;padding:80px 48px}
.value-card{border:1px solid var(--border);border-radius:var(--radius);padding:36px;transition:all .5s var(--ease);background:var(--surface);backdrop-filter:blur(10px)}
.value-card:hover{border-color:var(--border-hover);transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.value-icon{font-size:1.8rem;margin-bottom:16px}
.value-card h3{font-family:var(--serif);color:var(--ivory);font-size:1.1rem;margin-bottom:10px}
.value-card p{color:var(--muted);font-size:.83rem;line-height:1.7}
.team-section{text-align:center;padding:100px 48px;max-width:1200px;margin:0 auto}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:48px}
.team-card{text-align:center}
.team-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;margin:0 auto 16px;border:2px solid var(--border)}
.team-avatar canvas{width:100%;height:100%}
.team-card h4{font-family:var(--serif);color:var(--ivory);font-size:1rem;margin-bottom:4px}
.team-card p{font-size:.75rem;color:var(--muted)}

/* ── HERO BTN VARIANTS ── */
.btn-hero-primary{display:inline-flex;align-items:center;gap:10px;padding:14px 30px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));border:none;border-radius:var(--radius-pill);color:var(--bg);font-weight:600;font-size:.88rem;cursor:none;transition:all .3s;font-family:var(--sans)}
.btn-hero-primary:hover{box-shadow:0 8px 30px var(--gold-glow)}
.btn-hero-ghost{display:inline-flex;align-items:center;gap:10px;padding:14px 30px;border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--text);font-size:.88rem;cursor:none;transition:all .3s;font-family:var(--sans);background:var(--surface);backdrop-filter:blur(10px)}
.btn-hero-ghost:hover{border-color:var(--gold);color:var(--gold)}

@media(max-width:768px){
  .profile-body{grid-template-columns:1fr;padding:24px}
  .dashboard{grid-template-columns:1fr}
  .dash-sidebar{display:none}
  .stats-row{grid-template-columns:1fr 1fr}
  .values-grid{grid-template-columns:1fr;padding:40px 24px}
  .team-grid{grid-template-columns:1fr 1fr}
  .gallery-wall{grid-template-columns:1fr 1fr}
  .style-grid,.size-grid{grid-template-columns:1fr 1fr}
}

/* ── UPGRADE MODAL ── */
.upgrade-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);z-index:10000;display:none;align-items:center;justify-content:center;padding:24px}
.upgrade-modal.open{display:flex}
.upgrade-modal-box{background:var(--bg2);border:1px solid rgba(167,139,250,.2);border-radius:20px;padding:40px;max-width:520px;width:100%;text-align:center;position:relative;animation:modalIn .4s var(--ease)}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:none}}
.upgrade-modal-close{position:absolute;top:16px;right:20px;background:none;border:none;color:var(--muted);font-size:1.6rem;cursor:pointer;transition:color .3s;line-height:1}
.upgrade-modal-close:hover{color:var(--ivory)}
.upgrade-modal-icon{font-size:2.4rem;margin-bottom:16px}
.upgrade-modal-box h2{font-family:var(--serif);font-size:1.6rem;color:var(--ivory);margin-bottom:12px}
.upgrade-modal-box>p{color:var(--muted);font-size:.85rem;line-height:1.6;margin-bottom:28px}
.upgrade-plans{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.upgrade-plan{border:1px solid rgba(167,139,250,.15);border-radius:var(--radius-sm);padding:20px 12px;cursor:pointer;transition:all .3s;background:rgba(124,58,237,.04);position:relative}
.upgrade-plan:hover{border-color:rgba(167,139,250,.5);transform:translateY(-4px);box-shadow:0 12px 32px rgba(124,58,237,.15)}
.upgrade-plan-best{border-color:rgba(167,139,250,.35);background:rgba(124,58,237,.08)}
.upgrade-plan-name{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#c4b5fd;margin-bottom:8px}
.upgrade-plan-price{font-family:var(--display);font-size:1.4rem;color:var(--ivory);font-weight:700}
.upgrade-plan-badge{position:absolute;top:-8px;right:-4px;background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;font-size:.55rem;font-weight:600;padding:3px 8px;border-radius:10px;letter-spacing:.06em}

/* ── SUBSCRIPTION BADGES ── */
.sub-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:var(--radius-pill);font-size:.65rem;font-weight:600;letter-spacing:.06em}
.sub-badge-free{background:rgba(250,204,21,.1);color:#facc15;border:1px solid rgba(250,204,21,.2)}
.sub-badge-pro{background:rgba(167,139,250,.12);color:#a78bfa;border:1px solid rgba(167,139,250,.25)}

/* ── EMPTY STATE ── */
.empty-state{padding:60px 24px;text-align:center;border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface)}
.empty-state-icon{font-size:2.4rem;margin-bottom:16px;opacity:.6}
.empty-state-title{font-family:var(--serif);font-size:1.1rem;color:var(--ivory);margin-bottom:8px}
.empty-state-text{color:var(--muted);font-size:.82rem;margin-bottom:20px;line-height:1.6}

/* ── ART DROPZONE (drag & drop / gallery / camera) ── */
.art-dropzone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:160px;padding:32px 24px;border:2px dashed rgba(167,139,250,.45);border-radius:var(--radius);background:rgba(124,58,237,.06);text-align:center;cursor:pointer;transition:all .35s var(--ease);-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.art-dropzone:hover,.art-dropzone:focus-visible{border-color:rgba(201,169,110,.7);background:rgba(201,169,110,.05)}
.art-dropzone.drag-over{border-color:var(--gold);background:rgba(201,169,110,.1);transform:scale(1.01);box-shadow:0 0 0 3px rgba(201,169,110,.12)}
.art-dropzone-icon{width:48px;height:48px;color:#a78bfa;display:flex;align-items:center;justify-content:center}
.art-dropzone-icon svg{width:40px;height:40px}
.art-dropzone-title{color:var(--ivory);font-size:.95rem;font-weight:500}
.art-dropzone-hint{color:var(--muted);font-size:.8rem}
.art-upload-btn{margin-top:8px;padding:10px 22px;border:1px solid var(--gold);border-radius:var(--radius-pill);background:rgba(201,169,110,.12);color:var(--gold);font-family:var(--sans);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .25s;display:inline-block}
.art-upload-btn:hover{background:rgba(201,169,110,.22);transform:translateY(-1px)}
#artFileInput{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
label.art-dropzone{cursor:pointer;display:flex}
.art-dropzone-hit{width:100%;cursor:pointer}
.art-dropzone-mobile{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:14px;width:100%}
.art-dropzone-mobile button{pointer-events:auto;cursor:pointer;padding:10px 16px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg3);color:var(--text);font-family:var(--sans);font-size:.78rem;transition:all .25s}
.art-dropzone-mobile button:hover{border-color:var(--gold);color:var(--gold)}
.art-dropzone--compact{min-height:120px;padding:24px 16px}
.art-dropzone--compact .art-dropzone-icon{width:40px;height:40px}
.art-dropzone--compact .art-dropzone-icon svg{width:32px;height:32px}

/* ── UPLOAD BUTTONS (legacy) ── */
.upload-btn-group{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.upload-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:28px 16px;min-height:100px;border:2px dashed var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;transition:all .3s;color:var(--muted);font-family:var(--sans);font-size:.82rem;text-align:center;-webkit-tap-highlight-color:transparent;user-select:none}
.upload-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,169,110,.03)}
.upload-btn:active{transform:scale(.96);border-color:var(--gold);background:rgba(201,169,110,.06)}
.upload-btn-icon{font-size:2rem;line-height:1}
.upload-btn input[type="file"]{display:none}

/* ── IMAGE PREVIEW ── */
.img-preview{position:relative;margin-bottom:16px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);display:none;transition:all .3s}
.img-preview.has-image{display:block;border-color:rgba(52,211,153,.3);box-shadow:0 0 12px rgba(52,211,153,.08)}
.img-preview img{width:100%;max-height:260px;object-fit:cover;display:block}
.img-preview-info{padding:12px 14px;background:var(--bg3);display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--muted)}
.img-preview-remove{background:none;border:none;color:#f87171;cursor:pointer;font-size:.78rem;font-weight:600;padding:4px 8px;border-radius:4px;transition:background .2s}
.img-preview-remove:hover{text-decoration:underline;background:rgba(248,113,113,.08)}

/* ── ROLE SELECTION MODAL (Login Google) ── */
.role-modal{position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(10px);z-index:10001;display:none;align-items:center;justify-content:center;padding:24px}
.role-modal.open{display:flex}
.role-modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:36px;max-width:420px;width:100%;text-align:center;animation:modalIn .4s var(--ease)}
.role-modal-box h3{font-family:var(--serif);font-size:1.3rem;color:var(--ivory);margin-bottom:8px}
.role-modal-box>p{color:var(--muted);font-size:.82rem;margin-bottom:24px}
.role-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
.role-modal-card{padding:24px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .3s;background:var(--bg3);text-align:center}
.role-modal-card:hover{border-color:var(--border-hover)}
.role-modal-card.selected{border-color:var(--gold);background:rgba(201,169,110,.06);box-shadow:0 0 0 1px rgba(201,169,110,.15)}
.role-modal-card .type-icon{font-size:1.8rem;margin-bottom:10px}
.role-modal-card strong{display:block;color:var(--ivory);font-size:.88rem;margin-bottom:4px}
.role-modal-card span{font-size:.72rem;color:var(--muted)}
.role-modal-proceed{width:100%;padding:13px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));border:none;border-radius:var(--radius-pill);color:var(--bg);font-weight:600;font-size:.88rem;cursor:pointer;transition:all .3s;font-family:var(--sans)}
.role-modal-proceed:hover{box-shadow:0 8px 30px var(--gold-glow)}
.role-modal-cancel{display:inline-block;margin-top:12px;color:var(--muted);font-size:.78rem;cursor:pointer;background:none;border:none;font-family:var(--sans)}
.role-modal-cancel:hover{color:var(--ivory)}

/* ── STAR RATING ── */
.star-rating{display:inline-flex;gap:4px;font-size:1.4rem;cursor:pointer}
.star-rating .star{color:var(--border);transition:color .2s}
.star-rating .star.active{color:var(--gold)}
.star-rating .star:hover,.star-rating .star:hover~.star{color:var(--gold)}

/* ── TOGGLE SWITCH ── */
.toggle-wrap{display:flex;align-items:center;gap:12px;cursor:pointer}
.toggle-switch{width:42px;height:24px;border-radius:12px;background:var(--bg4);border:1px solid var(--border);position:relative;transition:all .3s;flex-shrink:0}
.toggle-switch::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--muted);transition:all .3s}
.toggle-switch.on{background:rgba(167,139,250,.2);border-color:rgba(167,139,250,.4)}
.toggle-switch.on::after{left:20px;background:#a78bfa}
.toggle-label{font-size:.82rem;color:var(--text)}

/* ── PORTFOLIO IMAGE CARDS ── */
.portfolio-img-card{position:relative;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg3);transition:all .4s var(--ease)}
.portfolio-img-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.3)}
.portfolio-img-card img{width:100%;height:160px;object-fit:cover;display:block}
.portfolio-img-card-info{padding:12px 14px}
.portfolio-img-card-title{font-family:var(--serif);font-size:.88rem;color:var(--ivory);margin-bottom:4px}
.portfolio-img-card-price{font-family:var(--display);font-size:.82rem;color:var(--gold);font-weight:600}
.portfolio-img-card-del{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.7);border:1px solid rgba(248,113,113,.3);color:#f87171;font-size:.9rem;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .3s}
.portfolio-img-card:hover .portfolio-img-card-del{opacity:1}
.portfolio-img-card-del:hover{background:rgba(248,113,113,.2);border-color:#f87171}
.portfolio-status-badge{position:absolute;top:8px;left:8px;font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:999px;background:rgba(0,0,0,.72);border:1px solid}
.portfolio-img-card-actions{position:absolute;bottom:0;left:0;right:0;display:flex;gap:4px;justify-content:flex-end;padding:8px;background:linear-gradient(to top,rgba(0,0,0,.85),transparent);opacity:0;transition:opacity .3s}
.portfolio-img-card:hover .portfolio-img-card-actions{opacity:1}
.portfolio-img-card-actions button{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:rgba(10,10,10,.8);color:var(--ivory);font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.portfolio-img-card-actions button:hover{border-color:var(--gold);color:var(--gold)}
.portfolio-img-card-actions button.del{color:#f87171;border-color:rgba(248,113,113,.35)}
.portfolio-img-card-actions button.del:hover{background:rgba(248,113,113,.15)}

/* ── NOTIFICATION CHECKBOX STYLED ── */
.notif-check{display:flex;gap:12px;align-items:center;padding:10px 0;cursor:pointer}
.notif-check input[type="checkbox"]{width:18px;height:18px;accent-color:var(--gold);cursor:pointer}
.notif-check span{color:var(--text);font-size:.85rem}

/* ── MOBILE DASHBOARD NAV ── */
.dash-mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1px solid var(--border);z-index:999;padding:8px 0}
.dash-mobile-nav-inner{display:flex;justify-content:space-around}
.dash-mobile-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 8px;color:var(--muted);font-size:.6rem;letter-spacing:.04em;cursor:pointer;transition:color .3s;background:none;border:none;font-family:var(--sans)}
.dash-mobile-btn.active{color:var(--gold)}
.dash-mobile-btn svg{width:20px;height:20px}

@media(max-width:768px){
  .dash-mobile-nav{display:block}
  .dash-main{padding:24px 16px 100px}
  .upload-btn-group{grid-template-columns:1fr}
  .upgrade-plans{grid-template-columns:1fr}
  .role-modal-grid{grid-template-columns:1fr}
}

/* ── SKELETON LOADERS ── */
.skeleton-card{position:relative;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg3)}
.skeleton-card .skeleton-img{width:100%;height:200px;background:linear-gradient(110deg,var(--bg3) 8%,rgba(201,169,110,.04) 18%,var(--bg3) 33%);background-size:200% 100%;animation:skeleton-shimmer 1.6s linear infinite}
.skeleton-card .skeleton-body{padding:14px}
.skeleton-card .skeleton-line{height:12px;border-radius:6px;background:linear-gradient(110deg,var(--bg3) 8%,rgba(201,169,110,.06) 18%,var(--bg3) 33%);background-size:200% 100%;animation:skeleton-shimmer 1.6s linear infinite;margin-bottom:10px}
.skeleton-card .skeleton-line:nth-child(1){width:75%}
.skeleton-card .skeleton-line:nth-child(2){width:50%}
.skeleton-card .skeleton-line:nth-child(3){width:60%;margin-bottom:0}
@keyframes skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Skeleton for gallery frames */
.skeleton-frame{position:relative;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;background:linear-gradient(110deg,var(--bg3) 8%,rgba(201,169,110,.04) 18%,var(--bg3) 33%);background-size:200% 100%;animation:skeleton-shimmer 1.6s linear infinite}
.skeleton-frame .skeleton-label{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(to top,rgba(5,5,5,.7),transparent)}
.skeleton-frame .skeleton-label .skeleton-line{height:10px;border-radius:4px;background:rgba(201,169,110,.08);margin-bottom:8px}
.skeleton-frame .skeleton-label .skeleton-line:nth-child(1){width:60%}
.skeleton-frame .skeleton-label .skeleton-line:nth-child(2){width:40%}

/* Skeleton for featured carousel */
.skeleton-featured{width:100%;aspect-ratio:1;border-radius:var(--radius);background:linear-gradient(110deg,var(--bg3) 8%,rgba(201,169,110,.04) 18%,var(--bg3) 33%);background-size:200% 100%;animation:skeleton-shimmer 1.6s linear infinite}

/* Skeleton for artist cards */
.skeleton-artist{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg3)}
.skeleton-artist .skeleton-img{width:100%;height:240px;background:linear-gradient(110deg,var(--bg3) 8%,rgba(201,169,110,.04) 18%,var(--bg3) 33%);background-size:200% 100%;animation:skeleton-shimmer 1.6s linear infinite}
.skeleton-artist .skeleton-body{padding:16px}
.skeleton-artist .skeleton-line{height:12px;border-radius:6px;background:linear-gradient(110deg,var(--bg3) 8%,rgba(201,169,110,.06) 18%,var(--bg3) 33%);background-size:200% 100%;animation:skeleton-shimmer 1.6s linear infinite;margin-bottom:10px}
.skeleton-artist .skeleton-line:nth-child(1){width:60%}
.skeleton-artist .skeleton-line:nth-child(2){width:45%;margin-bottom:0}

/* ── DELETE CONFIRMATION MODAL ── */
.delete-confirm-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);z-index:10002;display:none;align-items:center;justify-content:center;padding:24px}
.delete-confirm-modal.open{display:flex}
.delete-confirm-box{background:var(--bg2);border:1px solid rgba(248,113,113,.2);border-radius:20px;padding:36px;max-width:420px;width:100%;text-align:center;position:relative;animation:modalIn .4s var(--ease)}
.delete-confirm-box .delete-icon{width:56px;height:56px;border-radius:50%;background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:1.6rem}
.delete-confirm-box h3{font-family:var(--serif);font-size:1.2rem;color:var(--ivory);margin-bottom:8px}
.delete-confirm-box p{color:var(--muted);font-size:.84rem;line-height:1.6;margin-bottom:6px}
.delete-confirm-box .delete-artwork-name{color:#fca5a5;font-weight:600;font-size:.9rem;margin-bottom:24px;display:block}
.delete-confirm-btns{display:flex;gap:12px;justify-content:center}
.delete-confirm-btns .btn-cancel{padding:12px 28px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--text);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s;font-family:var(--sans)}
.delete-confirm-btns .btn-cancel:hover{border-color:var(--gold);color:var(--ivory)}
.delete-confirm-btns .btn-delete{padding:12px 28px;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:var(--radius-pill);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s;font-family:var(--sans)}
.delete-confirm-btns .btn-delete:hover{box-shadow:0 8px 30px rgba(239,68,68,.3);transform:translateY(-1px)}
.delete-confirm-btns .btn-delete:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* ── UPLOAD STEP TOAST ── */
.upload-step-indicator{display:flex;align-items:center;gap:8px;font-size:.82rem}
.upload-step-indicator .step-spinner{width:16px;height:16px;border:2px solid rgba(201,169,110,.3);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
