/* ═══════════════════════════════════════════════════════
   XOFA TECHNOLOGY — main.css v4.0
   Premium Luxury Redesign
   Palette: Obsidian · Ivory · Champagne Gold
   Type: Playfair Display · Outfit · Space Mono
═══════════════════════════════════════════════════════ */

/* ─── TOKENS ─── */
:root {
  --bg-primary:    #080808;
  --bg-secondary:  #0f0f0f;
  --bg-tertiary:   #151515;
  --bg-elevated:   #1c1c1c;

  --text-primary:  #F2EDE8;
  --text-secondary:#8A8480;
  --text-muted:    #3E3A37;
  --text-inverse:  #080808;

  --gold:          #C8A97E;
  --gold-light:    #E2CBA8;
  --gold-dim:      rgba(200,169,126,.1);
  --gold-border:   rgba(200,169,126,.22);

  --border:        rgba(242,237,232,.06);
  --border-soft:   rgba(242,237,232,.03);

  --font-display:  'Playfair Display', Georgia, serif;
  --font-body:     'Outfit', system-ui, sans-serif;
  --font-mono:     'Space Mono', monospace;
}

/* ─── RESET ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{
  background:var(--bg-primary);
  color:var(--text-primary);
  font-family:var(--font-body);
  font-weight:300;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit}
button{font-family:inherit}

/* ─── FONT IMPORT ─── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Outfit:wght@200;300;400;500;600&family=Space+Mono:wght@400;700&display=swap');

/* ─── CURSOR ─── */
.cursor{
  width:8px;height:8px;
  background:var(--gold);border-radius:50%;
  position:fixed;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .15s,height .15s,opacity .15s;
}
.cursor-follower{
  width:30px;height:30px;
  border:1px solid var(--gold-border);border-radius:50%;
  position:fixed;pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:transform .12s ease,opacity .2s;
}
.cursor.hover{width:24px;height:24px;opacity:.5}
@media(max-width:768px){.cursor,.cursor-follower{display:none}body{cursor:auto}}

/* ─── SCROLL PROGRESS ─── */
.scroll-indicator{position:fixed;top:0;left:0;width:100%;height:1px;z-index:9997}
.scroll-progress{height:100%;background:var(--gold);width:0%;transition:width .1s linear}

/* ════════════════════════════════════════
   HEADER
════════════════════════════════════════ */
header{
  position:fixed;top:0;width:100%;
  padding:1.8rem 4rem;
  display:flex;justify-content:space-between;align-items:center;
  z-index:1000;
  background:rgba(8,8,8,.85);
  backdrop-filter:blur(24px) saturate(1.5);
  border-bottom:1px solid var(--border);
  transition:padding .4s ease;
}
header.scrolled{padding:1.1rem 4rem}

.logo-container{display:flex;align-items:center;gap:.9rem;text-decoration:none}
.site-logo-img{height:36px;width:auto;max-width:190px;object-fit:contain}

/* text fallback logo */
.logo-icon,.logo-text{display:none}
.logo-wordmark{
  font-family:var(--font-display);
  font-size:1.25rem;font-weight:600;
  letter-spacing:.06em;color:var(--text-primary);
}
.logo-sub{
  font-family:var(--font-mono);font-size:.5rem;
  color:var(--gold);letter-spacing:.2em;text-transform:uppercase;
  display:block;margin-top:.15rem;
}

nav{display:flex;gap:2.5rem;align-items:center}
nav a{
  color:var(--text-secondary);text-decoration:none;
  font-size:.78rem;font-weight:400;letter-spacing:.04em;
  transition:color .25s;position:relative;
}
nav a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:1px;background:var(--gold);
  transition:width .35s cubic-bezier(.16,1,.3,1);
}
nav a:hover{color:var(--text-primary)}
nav a:hover::after,nav a.active::after{width:100%}
nav a.active{color:var(--text-primary)}

.nav-cart{
  background:none;border:1px solid var(--border);
  color:var(--text-secondary);padding:.42rem 1.1rem;
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;
  cursor:pointer;transition:all .25s;
  display:flex;align-items:center;gap:.5rem;
}
.nav-cart:hover{border-color:var(--gold-border);color:var(--gold)}
.cart-count{
  background:var(--gold);color:var(--bg-primary);
  width:15px;height:15px;border-radius:50%;
  font-size:.58rem;display:flex;align-items:center;justify-content:center;font-weight:600;
  opacity:0;transform:scale(0);transition:all .2s;
}
.cart-count.visible{opacity:1;transform:scale(1)}

.user-profile-btn{
  background:none;border:1px solid var(--border);
  color:var(--text-secondary);padding:.38rem;
  cursor:pointer;transition:all .25s;
  width:33px;height:33px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;font-size:.82rem;
}
.user-profile-btn:hover{border-color:var(--gold-border);color:var(--gold)}
.user-profile-btn.logged-in{
  background:var(--gold);color:var(--bg-primary);
  border-color:var(--gold);font-family:var(--font-display);
  font-weight:600;font-size:.95rem;
}

.menu-toggle{
  display:none;background:none;border:1px solid var(--border);
  color:var(--text-primary);padding:.42rem .7rem;
  cursor:pointer;font-size:1rem;transition:all .25s;
}
.menu-toggle:hover{border-color:var(--gold-border);color:var(--gold)}

/* ════════════════════════════════════════
   HERO SLIDER
════════════════════════════════════════ */
.hero-slider{
  position:relative;height:100vh;min-height:580px;
  overflow:hidden;background:#000;
}
.hero-track{position:relative;height:100%;width:100%}
.hero-slide{
  position:absolute;inset:0;
  display:flex;align-items:flex-end;
  opacity:0;transition:opacity 1.1s ease;
  pointer-events:none;
}
.hero-slide.active{opacity:1;pointer-events:auto}

.hero-slide-bg{position:absolute;inset:0;z-index:0}
.hero-slide-bg img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.07);
  transition:transform 10s ease;
  filter:brightness(.38) saturate(.65);
}
.hero-slide.active .hero-slide-bg img{transform:scale(1)}
.hero-slide-dim{
  position:absolute;inset:0;
  background:
    linear-gradient(to top, rgba(8,8,8,.97) 0%, rgba(8,8,8,.55) 38%, transparent 75%),
    linear-gradient(to right, rgba(8,8,8,.65) 0%, transparent 65%);
}

.hero-slide-content{
  position:relative;z-index:2;
  /* bottom padding creates space above footer elements (dots, counter, progress) */
  padding:0 4.5rem 8rem;
  max-width:820px;
  /* ensure content never overflows hero height */
  box-sizing:border-box;
}

.hero-slide-eyebrow{
  display:block;
  font-family:var(--font-mono);
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.2rem;
  opacity:0;transform:translateY(6px);
  transition:opacity .7s .25s ease,transform .7s .25s ease;
}
.hero-slide.active .hero-slide-eyebrow{opacity:1;transform:translateY(0)}

.hero-slide-title{
  font-family:var(--font-display);
  /* clamp: floor=2.8rem (phones), fluid=8vw, ceiling=8.5rem (large desktop) */
  font-size:clamp(2.8rem,6vw,5.5rem);
  font-weight:400;font-style:italic;
  /* 1.05 gives enough room for italic ascenders/descenders — .88 was clipping */
  line-height:.85;
  letter-spacing:-.02em;
  margin-bottom:1.4rem;
}
.hero-slide-title .line{
  display:block;
  overflow:hidden;
  /* generous padding so italic ascenders at large sizes are never clipped;
     negative margin cancels the visual gap so line spacing stays tight */
  padding-top:0.22em;
  padding-bottom:0.16em;
  margin-top:-0.22em;
  margin-bottom:-0.16em;
}
.hero-slide-title .line-inner{
  display:block;
  transform:translateY(110%);
  transition:transform .9s cubic-bezier(.16,1,.3,1);
  /* mirror the padding so the glyph sits exactly where it should */
  padding-top:0.22em;
  padding-bottom:0.16em;
}
.hero-slide.active .hero-slide-title .line:nth-child(1) .line-inner{transform:translateY(0);transition-delay:.18s}
.hero-slide.active .hero-slide-title .line:nth-child(2) .line-inner{transform:translateY(0);transition-delay:.3s}
.hero-slide.active .hero-slide-title .line:nth-child(3) .line-inner{transform:translateY(0);transition-delay:.42s}
.hero-slide-title .accent{color:var(--gold);font-style:normal}

.hero-slide-desc{
  font-size:.88rem;color:var(--text-secondary);
  font-weight:300;line-height:1.75;max-width:460px;
  margin-bottom:1rem;
  opacity:0;transform:translateY(8px);
  transition:opacity .7s .55s ease,transform .7s .55s ease;
}
.hero-slide.active .hero-slide-desc{opacity:1;transform:translateY(0)}

.hero-slide-btns{
  display:flex;gap:.8rem;flex-wrap:wrap;
  opacity:0;transform:translateY(6px);
  transition:opacity .55s .72s ease,transform .55s .72s ease;
}
.hero-slide.active .hero-slide-btns{opacity:1;transform:translateY(0)}

.hero-counter{
  position:absolute;bottom:2rem;right:4.5rem;
  font-family:var(--font-mono);font-size:.65rem;
  color:var(--text-muted);letter-spacing:.1em;z-index:5;
}
.hero-counter-current{color:var(--gold)}

.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:46px;height:46px;
  background:rgba(242,237,232,.03);
  border:1px solid rgba(242,237,232,.09);
  color:rgba(242,237,232,.35);font-size:.95rem;
  cursor:pointer;transition:all .3s;
  display:none;align-items:center;justify-content:center;
}
.hero-arrow:hover{
  background:var(--gold-dim);
  border-color:var(--gold-border);color:var(--gold);
}
.hero-prev{left:2.5rem}
.hero-next{right:2.5rem}

.hero-dots{
  position:absolute;bottom:2rem;left:4.5rem;
  display:flex;gap:.55rem;z-index:5;align-items:center;
}
.hero-dot{
  width:22px;height:1px;background:rgba(242,237,232,.18);
  border:none;cursor:pointer;padding:0;transition:all .4s;
}
.hero-dot.active{width:38px;background:var(--gold)}

.hero-progress-bar{position:absolute;bottom:0;left:0;right:0;height:1px;background:rgba(242,237,232,.04);z-index:5}
.hero-progress-fill{height:100%;background:var(--gold);width:0%;transition:width .1s linear}

/* ════════════════════════════════════════
   STATS STRIP
════════════════════════════════════════ */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.stat-item{
  padding:3rem 2rem;text-align:center;
  border-right:1px solid var(--border);
  transition:background .35s;
}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:var(--bg-secondary)}
.stat-number{
  font-family:var(--font-display);
  font-size:3rem;font-weight:400;font-style:italic;
  color:var(--gold);display:block;line-height:1;margin-bottom:.4rem;
}
.stat-label{
  font-family:var(--font-mono);font-size:.6rem;
  color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;
}

/* ════════════════════════════════════════
   SECTIONS
════════════════════════════════════════ */
.section{padding:8rem 4.5rem}
.section-label{
  font-family:var(--font-mono);font-size:.62rem;
  color:var(--gold);text-transform:uppercase;letter-spacing:.2em;
  margin-bottom:1.1rem;display:block;
}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,5vw,4.8rem);
  font-weight:400;font-style:italic;
  line-height:.92;letter-spacing:-.01em;margin-bottom:1.4rem;
}
.section-sub{
  color:var(--text-secondary);font-weight:300;
  max-width:480px;font-size:.88rem;line-height:1.8;margin-bottom:4rem;
}

/* ════════════════════════════════════════
   EXPERTISE
════════════════════════════════════════ */
.skills-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;border-top:1px solid var(--border);
}
.skill-card{
  padding:2.8rem 2.5rem;
  border-bottom:1px solid var(--border);
  border-right:1px solid var(--border);
  transition:background .3s;position:relative;overflow:hidden;
}
.skill-card:nth-child(3n){border-right:none}
.skill-card::before{
  content:'';position:absolute;left:0;top:0;
  width:1px;height:0;background:var(--gold);
  transition:height .5s ease;
}
.skill-card:hover::before{height:100%}
.skill-card:hover{background:var(--bg-secondary)}
.skill-icon{width:36px;height:36px;object-fit:cover;filter:grayscale(1) brightness(.5);margin-bottom:1.4rem}
.skill-icon-emoji{font-size:1.5rem;margin-bottom:1.2rem;display:block}
.skill-title{
  font-family:var(--font-display);font-size:1.25rem;
  font-weight:500;margin-bottom:.6rem;letter-spacing:-.01em;
}
.skill-description{color:var(--text-secondary);font-size:.8rem;line-height:1.75;font-weight:300}

/* ════════════════════════════════════════
   PROJECTS
════════════════════════════════════════ */
.projects{background:var(--bg-secondary)}
.project-card{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid var(--border);min-height:380px;
}
.project-card:last-child{border-bottom:1px solid var(--border)}
.project-card:nth-child(even){direction:rtl}
.project-card:nth-child(even)>*{direction:ltr}
.project-image{position:relative;overflow:hidden;background:var(--bg-primary)}
.project-image img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.7) brightness(.5);
  transition:filter .7s,transform .7s;
}
.project-card:hover .project-image img{filter:grayscale(.3) brightness(.65);transform:scale(1.03)}
.project-info{
  padding:3.5rem;display:flex;
  flex-direction:column;justify-content:center;
  border-left:1px solid var(--border);
}
.project-card:nth-child(even) .project-info{border-left:none;border-right:1px solid var(--border)}
.project-number{
  font-family:var(--font-mono);font-size:.6rem;
  color:var(--gold);letter-spacing:.18em;margin-bottom:1rem;
}
.project-title{
  font-family:var(--font-display);font-size:2rem;
  font-weight:400;font-style:italic;
  margin-bottom:1rem;letter-spacing:-.01em;line-height:1.05;
}
.project-description{color:var(--text-secondary);font-size:.82rem;line-height:1.85;font-weight:300;margin-bottom:1.5rem}
.project-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.8rem}
.tag{
  padding:.18rem .6rem;background:transparent;
  border:1px solid var(--border);
  font-family:var(--font-mono);font-size:.6rem;
  letter-spacing:.06em;color:var(--text-muted);transition:all .25s;
}
.tag:hover{border-color:var(--gold-border);color:var(--gold)}
.project-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-mono);font-size:.68rem;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);text-decoration:none;transition:gap .3s;
}
.project-link:hover{gap:1rem}

/* ════════════════════════════════════════
   MARKETPLACE — Homepage preview
════════════════════════════════════════ */
.marketplace{background:var(--bg-primary)}

.mp-featured{
  display:grid;grid-template-columns:1.25fr 1fr;
  border:1px solid var(--border);margin-bottom:4rem;
  min-height:360px;overflow:hidden;
}
.mp-featured-visual{position:relative;overflow:hidden;background:var(--bg-secondary)}
.mp-featured-visual img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.48) saturate(.6);
  transition:filter .7s,transform .7s;
}
.mp-featured:hover .mp-featured-visual img{filter:brightness(.58) saturate(.75);transform:scale(1.03)}
.mp-featured-badge{
  position:absolute;top:1.2rem;left:1.2rem;
  background:var(--gold);color:var(--bg-primary);
  font-family:var(--font-mono);font-size:.58rem;
  font-weight:700;padding:.22rem .65rem;
  letter-spacing:.14em;text-transform:uppercase;
}
.mp-featured-info{
  padding:3rem;display:flex;
  flex-direction:column;justify-content:center;
  background:var(--bg-secondary);border-left:1px solid var(--border);
}
.mp-featured-label{
  font-family:var(--font-mono);font-size:.58rem;
  color:var(--gold);letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:.9rem;
}
.mp-featured-title{
  font-family:var(--font-display);font-size:2.6rem;
  font-weight:400;font-style:italic;
  line-height:.95;letter-spacing:-.01em;margin-bottom:1rem;
}
.mp-featured-desc{
  color:var(--text-secondary);font-size:.84rem;
  line-height:1.8;font-weight:300;margin-bottom:1.8rem;
}
.mp-featured-price{display:flex;align-items:baseline;gap:.8rem;margin-bottom:2rem}
.mp-featured-price-current{
  font-family:var(--font-display);font-size:2.4rem;
  font-weight:400;font-style:italic;color:var(--gold);
}
.mp-featured-price-old{font-size:.88rem;color:var(--text-muted);text-decoration:line-through}

/* Home product carousel */
.home-carousel-wrap{position:relative;margin:0}
.home-carousel-viewport{overflow:hidden;border:1px solid var(--border)}
.home-carousel-track{display:flex;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.hc-card{
  flex:0 0 25%;min-width:0;
  border-right:1px solid var(--border);
  background:var(--bg-secondary);
  cursor:pointer;transition:background .3s;
  display:flex;flex-direction:column;
}
.hc-card:hover{background:var(--bg-tertiary)}
.hc-img{height:165px;overflow:hidden;position:relative;background:var(--bg-primary);flex-shrink:0}
.hc-img img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.55) brightness(.5);
  transition:filter .5s,transform .5s;
}
.hc-card:hover .hc-img img{filter:grayscale(.2) brightness(.68);transform:scale(1.05)}
.hc-badges{position:absolute;top:.5rem;left:.5rem;display:flex;gap:.3rem}
.hc-body{padding:1.2rem;flex:1;display:flex;flex-direction:column}
.hc-type{font-family:var(--font-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin-bottom:.3rem}
.hc-title{font-family:var(--font-display);font-size:1rem;font-weight:500;letter-spacing:-.01em;margin-bottom:.4rem;line-height:1.2}
.hc-desc{font-size:.72rem;color:var(--text-secondary);line-height:1.6;font-weight:300;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.8rem}
.hc-footer{margin-top:auto;border-top:1px solid var(--border);padding-top:.8rem;display:flex;justify-content:space-between;align-items:center;gap:.4rem}
.hc-price{font-family:var(--font-display);font-size:1rem;font-weight:400;font-style:italic;color:var(--gold);flex-shrink:0}
.hc-price-old{font-size:.65rem;color:var(--text-muted);text-decoration:line-through;margin-left:.25rem;font-weight:300}
.hc-actions{display:flex;gap:.35rem;flex-shrink:0}
.hc-buy{
  padding:.28rem .62rem;background:var(--gold);border:none;
  color:var(--bg-primary);font-family:var(--font-mono);
  font-size:.6rem;letter-spacing:.04em;font-weight:700;
  cursor:pointer;transition:all .2s;white-space:nowrap;
}
.hc-buy:hover{background:var(--gold-light)}
.hc-buy.in-cart{background:transparent;border:1px solid var(--gold-border);color:var(--gold)}
.hc-demo{
  padding:.28rem .55rem;border:1px solid var(--border);
  color:var(--text-muted);font-family:var(--font-mono);font-size:.58rem;
  text-decoration:none;transition:all .2s;white-space:nowrap;
}
.hc-demo:hover{border-color:var(--gold-border);color:var(--gold)}
.carousel-arrow{
  position:absolute;top:82px;z-index:3;
  width:38px;height:38px;background:var(--bg-elevated);
  border:1px solid var(--border);color:var(--text-secondary);
  font-size:.85rem;cursor:pointer;transition:all .25s;
  display:flex;align-items:center;justify-content:center;
}
.carousel-arrow:hover:not(:disabled){border-color:var(--gold-border);color:var(--gold)}
.carousel-arrow:disabled{opacity:.18;cursor:not-allowed}
.carousel-prev{left:-19px}
.carousel-next{right:-19px}
.carousel-dots{display:flex;gap:.4rem;justify-content:center;margin-top:1.4rem}
.cdot{width:20px;height:1px;background:var(--border);border:none;cursor:pointer;padding:0;transition:all .3s}
.cdot.active{background:var(--gold);width:34px}

/* ─── Marketplace toolbar ─── */
.mp-toolbar{
  display:flex;gap:1rem;margin-bottom:2.5rem;
  align-items:center;flex-wrap:wrap;
  border-bottom:1px solid var(--border);padding-bottom:1.5rem;
}
.mp-filter-group{display:flex;gap:.4rem;flex-wrap:wrap}
.mp-filter-btn{
  padding:.35rem .95rem;background:transparent;
  border:1px solid var(--border);color:var(--text-muted);
  font-family:var(--font-mono);font-size:.62rem;
  letter-spacing:.08em;cursor:pointer;transition:all .2s;text-transform:uppercase;
}
.mp-filter-btn:hover{border-color:var(--gold-border);color:var(--gold)}
.mp-filter-btn.active{background:var(--gold);border-color:var(--gold);color:var(--bg-primary)}
.mp-search-wrap{display:flex;gap:.4rem;margin-left:auto;max-width:250px}
.mp-search{
  background:var(--bg-secondary);border:1px solid var(--border);
  color:var(--text-primary);padding:.42rem .9rem;
  font-family:var(--font-body);font-size:.78rem;font-weight:300;
  outline:none;flex:1;transition:border-color .25s;
}
.mp-search:focus{border-color:var(--gold-border)}
.mp-search::placeholder{color:var(--text-muted)}
.mp-sort{
  background:var(--bg-secondary);border:1px solid var(--border);
  color:var(--text-secondary);padding:.42rem .75rem;
  font-family:var(--font-mono);font-size:.62rem;cursor:pointer;outline:none;
}

/* ─── Product grid ─── */
.mp-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;border:1px solid var(--border);
}
.mp-card{
  background:var(--bg-secondary);
  border-right:1px solid var(--border);border-bottom:1px solid var(--border);
  transition:background .3s;cursor:pointer;
  display:flex;flex-direction:column;position:relative;
}
.mp-card:hover{background:var(--bg-tertiary)}
.mp-card-img-wrap{height:195px;overflow:hidden;position:relative;background:var(--bg-primary);flex-shrink:0}
.mp-card-img-wrap img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(.55) brightness(.48);
  transition:filter .5s,transform .5s;
}
.mp-card:hover .mp-card-img-wrap img{filter:grayscale(.2) brightness(.65);transform:scale(1.04)}
.mp-card-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:3rem;color:var(--text-muted);font-style:italic;
}
.mp-card-badges{position:absolute;top:.6rem;left:.6rem;display:flex;gap:.3rem;flex-wrap:wrap}
.mp-card-quick{
  position:absolute;bottom:.6rem;right:.6rem;opacity:0;
  background:rgba(8,8,8,.92);border:1px solid var(--border);
  color:var(--text-secondary);padding:.24rem .6rem;
  font-family:var(--font-mono);font-size:.58rem;cursor:pointer;
  transition:all .25s;transform:translateY(4px);
}
.mp-card:hover .mp-card-quick{opacity:1;transform:translateY(0)}
.mp-card-quick:hover{background:var(--gold);color:var(--bg-primary);border-color:var(--gold)}
.mp-card-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.mp-card-type{font-family:var(--font-mono);font-size:.56rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;margin-bottom:.4rem}
.mp-card-title{font-family:var(--font-display);font-size:1.1rem;font-weight:500;letter-spacing:-.01em;margin-bottom:.5rem;line-height:1.2;min-height:2.65rem}
.mp-card-rating{display:flex;align-items:center;gap:.3rem;font-size:.66rem;color:var(--text-muted);margin-bottom:.65rem}
.mp-card-rating .stars{color:var(--gold);letter-spacing:-.05em}
.mp-card-desc{color:var(--text-secondary);font-size:.75rem;line-height:1.7;font-weight:300;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1;margin-bottom:.9rem}
.mp-card-tags{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:1rem}
.mp-card-tag{font-family:var(--font-mono);font-size:.54rem;padding:.12rem .45rem;border:1px solid var(--border);color:var(--text-muted);letter-spacing:.06em}
.mp-card-footer{margin-top:auto;border-top:1px solid var(--border);padding-top:1rem}
.mp-card-price-block{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.7rem}
.mp-card-price{font-family:var(--font-display);font-size:1.2rem;font-weight:400;font-style:italic;color:var(--gold)}
.mp-card-price-old{font-size:.7rem;color:var(--text-muted);text-decoration:line-through}
.mp-card-foot-btns{display:grid;grid-template-columns:1fr auto;gap:.4rem}
.mp-card-btn{
  padding:.4rem .78rem;background:var(--gold);border:none;
  color:var(--bg-primary);font-family:var(--font-mono);
  font-size:.64rem;letter-spacing:.06em;font-weight:700;
  cursor:pointer;transition:all .2s;white-space:nowrap;
}
.mp-card-btn:hover{background:var(--gold-light)}
.mp-card-btn.in-cart{background:transparent;border:1px solid var(--gold-border);color:var(--gold)}
.mp-card-demo-link{
  padding:.4rem .68rem;border:1px solid var(--border);
  color:var(--text-muted);font-family:var(--font-mono);font-size:.6rem;
  text-decoration:none;display:flex;align-items:center;justify-content:center;
  white-space:nowrap;transition:all .2s;
}
.mp-card-demo-link:hover{border-color:var(--gold-border);color:var(--gold)}
.mp-results-count{font-family:var(--font-mono);font-size:.66rem;color:var(--text-muted);margin:1rem 0 1.5rem;letter-spacing:.06em}
.mp-results-count strong{color:var(--gold)}
.mp-empty{text-align:center;padding:5rem 2rem;color:var(--text-muted);font-family:var(--font-display);font-style:italic;font-size:1.1rem}
.mp-empty-icon{font-size:2rem;margin-bottom:1rem;display:block}

/* Featured carousel — marketplace page */
.mp-featured-carousel-section{position:relative;margin-bottom:3.5rem;overflow:hidden}
.mp-fc-track{position:relative;height:360px}
.mp-fc-slide{
  position:absolute;inset:0;
  display:grid;grid-template-columns:1.2fr 1fr;
  opacity:0;pointer-events:none;transition:opacity .7s ease;
  background:var(--bg-secondary);border:1px solid var(--border);
}
.mp-fc-slide.active{opacity:1;pointer-events:auto}
.mp-fc-visual{position:relative;overflow:hidden}
.mp-fc-visual img{width:100%;height:100%;object-fit:cover;filter:brightness(.45) saturate(.6);transition:transform 7s ease}
.mp-fc-slide.active .mp-fc-visual img{transform:scale(1.04)}
.mp-fc-overlay{position:absolute;inset:0;background:linear-gradient(to right,transparent 55%,var(--bg-secondary) 100%)}
.mp-fc-badge{
  position:absolute;top:1rem;left:1rem;
  background:var(--gold);color:var(--bg-primary);
  font-family:var(--font-mono);font-size:.56rem;
  font-weight:700;padding:.2rem .6rem;letter-spacing:.12em;text-transform:uppercase;
}
.mp-fc-info{padding:2.2rem;display:flex;flex-direction:column;justify-content:center;gap:.9rem}
.mp-fc-type{font-family:var(--font-mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.16em;color:var(--gold)}
.mp-fc-title{font-family:var(--font-display);font-size:1.85rem;font-weight:400;font-style:italic;line-height:.98;letter-spacing:-.01em}
.mp-fc-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.75;font-weight:300;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.mp-fc-tags{display:flex;gap:.35rem;flex-wrap:wrap}
.mp-fc-price{display:flex;align-items:baseline;gap:.6rem}
.mp-fc-price-now{font-family:var(--font-display);font-size:1.7rem;font-weight:400;font-style:italic;color:var(--gold)}
.mp-fc-price-was{font-size:.8rem;color:var(--text-muted);text-decoration:line-through}
.mp-fc-btns{display:flex;gap:.6rem;flex-wrap:wrap}
.mp-fc-prev,.mp-fc-next{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:40px;height:40px;background:rgba(8,8,8,.75);
  border:1px solid var(--border);color:var(--text-secondary);
  font-size:.9rem;cursor:pointer;transition:all .25s;
  display:flex;align-items:center;justify-content:center;
}
.mp-fc-prev:hover,.mp-fc-next:hover{border-color:var(--gold-border);color:var(--gold)}
.mp-fc-prev{left:1rem}
.mp-fc-next{right:1rem}
.mp-fc-dots{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);display:flex;gap:.4rem;z-index:5}
.mp-fc-dot{width:20px;height:1px;background:rgba(242,237,232,.15);border:none;cursor:pointer;padding:0;transition:all .3s}
.mp-fc-dot.active{background:var(--gold);width:32px}

.mp-main{padding:2rem 4.5rem 6rem}

/* ════════════════════════════════════════
   NEWSLETTER
════════════════════════════════════════ */
.mp-newsletter{
  display:flex;gap:2rem;align-items:center;
  justify-content:space-between;
  border:1px solid var(--border);padding:2.8rem 3.5rem;
  margin-top:4rem;background:var(--bg-secondary);
}
.mp-newsletter-text h3{font-family:var(--font-display);font-size:1.55rem;font-weight:400;font-style:italic;margin-bottom:.3rem}
.mp-newsletter-text p{font-size:.78rem;color:var(--text-secondary);font-weight:300}
.mp-newsletter-form{display:flex;gap:.5rem;flex:0 0 auto}
.mp-newsletter-input{
  background:var(--bg-primary);border:1px solid var(--border);
  color:var(--text-primary);padding:.58rem 1rem;
  font-family:var(--font-body);font-size:.8rem;font-weight:300;
  outline:none;width:230px;transition:border-color .25s;
}
.mp-newsletter-input:focus{border-color:var(--gold-border)}
.mp-newsletter-input::placeholder{color:var(--text-muted)}
.mp-newsletter-btn{
  padding:.58rem 1.4rem;background:var(--gold);border:none;
  color:var(--bg-primary);font-family:var(--font-mono);
  font-size:.66rem;font-weight:700;letter-spacing:.08em;
  cursor:pointer;transition:all .25s;white-space:nowrap;
}
.mp-newsletter-btn:hover{background:var(--gold-light)}

/* ════════════════════════════════════════
   CONTACT TEASER
════════════════════════════════════════ */
.contact{
  padding:10rem 4.5rem;text-align:center;
  background:var(--bg-secondary);border-top:1px solid var(--border);
}
.contact-title{
  font-family:var(--font-display);
  font-size:clamp(3rem,8vw,8rem);
  font-weight:400;font-style:italic;
  letter-spacing:-.02em;line-height:.88;margin-bottom:2rem;
}
.contact-title .accent{color:var(--gold);font-style:normal}
.contact-email{
  font-family:var(--font-mono);font-size:.8rem;
  letter-spacing:.14em;color:var(--gold);
  text-decoration:none;display:inline-block;
  margin-bottom:2.5rem;transition:opacity .25s;
}
.contact-email:hover{opacity:.65}
.social-links{display:flex;justify-content:center;gap:.9rem}
.social-link{
  width:38px;height:38px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;color:var(--text-muted);
  font-family:var(--font-mono);font-size:.6rem;letter-spacing:.04em;
  transition:all .25s;
}
.social-link:hover{border-color:var(--gold-border);color:var(--gold);background:var(--gold-dim)}

/* ════════════════════════════════════════
   FOOTER
════════════════════════════════════════ */
footer{
  background:var(--bg-primary);
  border-top:1px solid var(--border);
  padding:5rem 4.5rem 3rem;
}
.footer-grid{
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:3.5rem;
  margin-bottom:3.5rem;padding-bottom:3.5rem;
  border-bottom:1px solid var(--border);
}
.footer-brand{max-width:300px}
.footer-logo-container{margin-bottom:1.2rem}
.footer-logo-img{height:auto;max-height:48px;width:auto;max-width:220px;object-fit:contain;display:block;background:transparent}
.footer-logo-text .logo-name,.footer-logo-text .logo-tagline{display:none}
.footer-desc{color:var(--text-muted);font-size:.76rem;line-height:1.8;font-weight:300;margin-bottom:1.5rem}
.footer-social{display:flex;gap:.5rem}
.footer-social-link{
  width:30px;height:30px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;color:var(--text-muted);
  font-family:var(--font-mono);font-size:.58rem;transition:all .25s;
}
.footer-social-link:hover{border-color:var(--gold-border);color:var(--gold)}
.footer-col h4{
  font-family:var(--font-mono);font-size:.58rem;
  color:var(--gold);text-transform:uppercase;letter-spacing:.18em;margin-bottom:1.2rem;
}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.55rem}
.footer-links a{color:var(--text-muted);text-decoration:none;font-size:.76rem;font-weight:300;transition:color .22s}
.footer-links a:hover{color:var(--text-secondary)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font-mono);font-size:.6rem;
  color:var(--text-muted);letter-spacing:.04em;
  flex-wrap:wrap;gap:1rem;
}
.footer-legal{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-legal a{color:var(--text-muted);text-decoration:none;transition:color .2s}
.footer-legal a:hover{color:var(--text-secondary)}

/* ════════════════════════════════════════
   BUTTONS
════════════════════════════════════════ */
.btn{
  padding:.72rem 2rem;
  font-family:var(--font-mono);font-size:.68rem;
  font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;border:1px solid;transition:all .3s;
  cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;overflow:hidden;
}
.btn-primary{background:var(--gold);color:var(--bg-primary);border-color:var(--gold)}
.btn-primary:hover{background:var(--gold-light);border-color:var(--gold-light)}
.btn-secondary{background:transparent;color:var(--text-secondary);border-color:var(--border)}
.btn-secondary:hover{border-color:var(--gold-border);color:var(--gold)}
.btn-sm{padding:.46rem 1.2rem;font-size:.62rem}
.btn-full{width:100%;justify-content:center}
.btn-danger{background:transparent;color:#c0392b;border-color:rgba(192,57,43,.3)}
.btn-danger:hover{background:rgba(192,57,43,.1)}

/* ════════════════════════════════════════
   BADGES
════════════════════════════════════════ */
.mp-badge{font-family:var(--font-mono);font-size:.54rem;padding:.14rem .48rem;letter-spacing:.1em;text-transform:uppercase}
.mp-badge-popular{background:var(--gold-dim);color:var(--gold);border:1px solid var(--gold-border)}
.mp-badge-sale{background:rgba(192,57,43,.1);color:#c0392b;border:1px solid rgba(192,57,43,.25)}
.mp-badge-new{background:rgba(242,237,232,.05);color:var(--text-secondary);border:1px solid var(--border)}
.badge{display:inline-block;padding:.2rem .6rem;font-family:var(--font-mono);font-size:.6rem}
.badge-gold{background:var(--gold-dim);color:var(--gold);border:1px solid var(--gold-border)}
.badge-orange{background:rgba(192,57,43,.1);color:#c0392b;border:1px solid rgba(192,57,43,.25)}
.badge-blue{background:rgba(242,237,232,.04);color:var(--text-secondary);border:1px solid var(--border)}

/* ════════════════════════════════════════
   PAGE HERO (inner pages)
════════════════════════════════════════ */
.page-hero{
  padding:11rem 4.5rem 5.5rem;
  background:var(--bg-secondary);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
.page-hero::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 80% at 50% 100%, rgba(200,169,126,.04) 0%, transparent 70%);
  pointer-events:none;
}
.grid-bg{display:none}
.page-hero-label{font-family:var(--font-mono);font-size:.6rem;color:var(--gold);letter-spacing:.22em;text-transform:uppercase;margin-bottom:1.2rem;display:block}
.page-hero-title{font-family:var(--font-display);font-size:clamp(2.8rem,6vw,6rem);font-weight:400;font-style:italic;letter-spacing:-.02em;margin-bottom:1.2rem;line-height:.9}
.page-hero-sub{color:var(--text-secondary);max-width:500px;font-weight:300;font-size:.88rem;line-height:1.8}

/* ════════════════════════════════════════
   MODALS
════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.9);
  backdrop-filter:blur(6px);z-index:4000;
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .3s;
}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal{background:var(--bg-secondary);width:100%;max-width:860px;max-height:90vh;overflow-y:auto;border:1px solid var(--border);position:relative}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;z-index:1;padding:.3rem;transition:color .2s}
.modal-close:hover{color:var(--gold)}
.modal-hero{display:grid;grid-template-columns:1fr 1fr}
.modal-visual{height:280px;background:var(--bg-primary);overflow:hidden;position:relative}
.modal-visual img{width:100%;height:100%;object-fit:cover;filter:brightness(.5) saturate(.65)}
.modal-visual-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:4rem;font-style:italic;color:var(--text-muted)}
.modal-info{padding:2rem;background:var(--bg-tertiary)}
.modal-type{font-family:var(--font-mono);font-size:.6rem;color:var(--gold);text-transform:uppercase;letter-spacing:.16em;margin-bottom:.5rem}
.modal-title{font-family:var(--font-display);font-size:1.8rem;font-weight:400;font-style:italic;letter-spacing:-.01em;margin-bottom:.5rem}
.modal-rating{display:flex;align-items:center;gap:.6rem;font-size:.7rem;color:var(--text-muted);margin-bottom:1rem}
.stars{color:var(--gold);letter-spacing:-.05em}
.rating-detail{color:var(--text-muted)}
.modal-price{font-family:var(--font-display);font-size:2.2rem;font-weight:400;font-style:italic;color:var(--gold);margin-bottom:1.5rem}
.modal-price-old{font-size:.9rem;color:var(--text-muted);text-decoration:line-through;margin-left:.4rem}
.modal-buy-btn{width:100%;padding:.76rem;background:var(--gold);border:none;color:var(--bg-primary);font-family:var(--font-mono);font-size:.68rem;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:all .25s;margin-bottom:.5rem}
.modal-buy-btn:hover{background:var(--gold-light)}
.modal-demo-btn{width:100%;padding:.76rem;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-mono);font-size:.68rem;cursor:pointer;transition:all .25s;text-decoration:none;display:block;text-align:center}
.modal-demo-btn:hover{border-color:var(--gold-border);color:var(--gold)}
.modal-body{padding:2rem}
.modal-desc{color:var(--text-secondary);line-height:1.85;margin-bottom:2rem;font-size:.86rem;font-weight:300}
.modal-features-title{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.9rem}
.modal-features{list-style:none;display:flex;flex-direction:column;gap:.45rem;margin-bottom:2rem}
.modal-features li{font-size:.8rem;color:var(--text-secondary);padding-left:1.2rem;position:relative;font-weight:300}
.modal-features li::before{content:'—';position:absolute;left:0;color:var(--gold)}
.modal-tech{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:2rem}
.modal-tech span{padding:.22rem .62rem;border:1px solid var(--border);font-family:var(--font-mono);font-size:.64rem;color:var(--text-muted)}

/* ════════════════════════════════════════
   REVIEWS
════════════════════════════════════════ */
.reviews-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}
.reviews-avg{font-family:var(--font-display);font-size:1.5rem;font-weight:400;font-style:italic;color:var(--gold)}
.reviews-total{font-size:.72rem;color:var(--text-muted);margin-left:.3rem}
.review-form-toggle{padding:.38rem 1rem;background:transparent;border:1px solid var(--gold-border);color:var(--gold);font-family:var(--font-mono);font-size:.64rem;letter-spacing:.06em;cursor:pointer;transition:all .25s}
.review-form-toggle:hover{background:var(--gold-dim)}
.review-form{display:none;background:var(--bg-tertiary);padding:1.2rem;border:1px solid var(--border);margin-bottom:1.2rem}
.review-form.active{display:block}
.star-rating{display:flex;gap:.3rem;margin-bottom:1rem}
.star-btn{background:none;border:none;font-size:1.4rem;color:var(--border);cursor:pointer;transition:color .2s;padding:0}
.star-btn:hover,.star-btn.active{color:var(--gold)}
.review-textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);padding:.72rem;font-family:var(--font-body);font-size:.8rem;font-weight:300;resize:vertical;min-height:100px;outline:none;margin-bottom:1rem}
.review-textarea:focus{border-color:var(--gold-border)}
.review-submit{padding:.52rem 1.4rem;background:var(--gold);border:none;color:var(--bg-primary);font-family:var(--font-mono);font-size:.66rem;font-weight:700;letter-spacing:.08em;cursor:pointer;transition:all .25s}
.review-submit:hover{background:var(--gold-light)}
.product-reviews-list{display:flex;flex-direction:column;gap:1rem}
.product-review-item{background:var(--bg-tertiary);padding:1.2rem;border:1px solid var(--border)}
.review-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.6rem}
.review-author{font-size:.82rem;font-weight:500}
.review-stars{color:var(--gold);font-size:.7rem;letter-spacing:-.05em}
.review-content{font-size:.78rem;color:var(--text-secondary);line-height:1.75;margin-bottom:.5rem;font-weight:300}
.review-footer{display:flex;justify-content:space-between;align-items:center}
.review-time{font-family:var(--font-mono);font-size:.62rem;color:var(--text-muted)}
.review-helpful{display:flex;gap:.5rem}
.helpful-btn{background:none;border:1px solid var(--border);color:var(--text-muted);padding:.16rem .48rem;font-family:var(--font-mono);font-size:.6rem;cursor:pointer;transition:all .25s}
.helpful-btn:hover{border-color:var(--gold-border);color:var(--gold)}

/* ════════════════════════════════════════
   CART DRAWER
════════════════════════════════════════ */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:2400;opacity:0;pointer-events:none;transition:opacity .3s}
.cart-overlay.open{opacity:1;pointer-events:auto}
.cart-drawer{position:fixed;top:0;right:-400px;width:380px;max-width:90vw;height:100%;background:var(--bg-secondary);border-left:1px solid var(--border);z-index:2500;transition:right .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.cart-drawer.open{right:0}
.cart-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.cart-header h3{font-family:var(--font-display);font-size:1.1rem;font-weight:400;font-style:italic}
.cart-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;transition:color .2s}
.cart-close:hover{color:var(--gold)}
.cart-items{flex:1;overflow-y:auto;padding:1rem}
.cart-empty{color:var(--text-muted);font-family:var(--font-display);font-style:italic;font-size:.9rem;text-align:center;padding:3rem .8rem;font-weight:300}
.cart-item{display:flex;gap:.8rem;align-items:center;padding:.8rem 0;border-bottom:1px solid rgba(242,237,232,.03)}
.cart-item-icon{width:38px;height:38px;background:var(--bg-primary);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.cart-item-icon img{width:100%;height:100%;object-fit:cover;filter:brightness(.55)}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:.8rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item-type{font-family:var(--font-mono);font-size:.58rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}
.cart-item-price{font-family:var(--font-display);font-size:.92rem;font-weight:400;font-style:italic;color:var(--gold);white-space:nowrap}
.cart-item-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.88rem;transition:color .2s;padding:0 2px}
.cart-item-remove:hover{color:#c0392b}
.cart-footer{padding:1.2rem;border-top:1px solid var(--border)}
.cart-total{display:flex;justify-content:space-between;margin-bottom:1rem}
.cart-total span:first-child{color:var(--text-secondary);font-size:.78rem}
.cart-total span:last-child{font-family:var(--font-display);font-size:1.15rem;font-weight:400;font-style:italic;color:var(--gold)}
.cart-secure-line{display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.56rem;color:var(--text-muted);padding:.4rem 0;letter-spacing:.07em}
.cart-secure-dot{width:4px;height:4px;border-radius:50%;background:var(--text-muted);flex-shrink:0}
.cart-checkout{width:100%;padding:.68rem;background:var(--gold);color:var(--bg-primary);border:none;font-family:var(--font-mono);font-size:.68rem;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:all .25s}
.cart-checkout:hover{background:var(--gold-light)}
.cart-checkout:disabled{opacity:.28;cursor:not-allowed}
.cart-gumroad-hint{font-family:var(--font-mono);font-size:.58rem;color:var(--text-muted);text-align:center;padding:.25rem 0;letter-spacing:.05em}

/* ════════════════════════════════════════
   SIDEBAR (auth / profile)
════════════════════════════════════════ */
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:3000;opacity:0;pointer-events:none;transition:opacity .3s}
.sidebar-overlay.open{opacity:1;pointer-events:auto}
.sidebar{position:fixed;top:0;right:-420px;width:400px;max-width:90vw;height:100%;background:var(--bg-secondary);border-left:1px solid var(--border);z-index:3001;transition:right .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}
.sidebar.open{right:0}
.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.sidebar-title{font-family:var(--font-display);font-size:1.1rem;font-weight:400;font-style:italic}
.sidebar-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;transition:color .2s}
.sidebar-close:hover{color:var(--gold)}
.sidebar-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg-tertiary)}
.sidebar-tab{flex:1;padding:.72rem 1rem;background:none;border:none;color:var(--text-muted);font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;cursor:pointer;transition:all .25s;border-bottom:1px solid transparent;text-transform:uppercase}
.sidebar-tab:hover{color:var(--text-secondary)}
.sidebar-tab.active{color:var(--gold);border-bottom-color:var(--gold);background:var(--bg-secondary)}
.sidebar-content{flex:1;overflow-y:auto;padding:1.5rem}

/* ─── Forms ─── */
.login-form,.register-form,.auth-form{display:flex;flex-direction:column;gap:1.1rem}
.auth-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.75;margin-bottom:.2rem;font-weight:300}
.req{color:#c0392b;margin-left:1px}
.auth-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.auth-switch{font-size:.74rem;color:var(--text-muted);text-align:center;padding-top:.4rem}
.link-btn{background:none;border:none;color:var(--gold);cursor:pointer;font-size:.74rem;font-family:var(--font-body);font-weight:300;text-decoration:underline;padding:0;transition:opacity .2s}
.link-btn:hover{opacity:.65}
.link-btn.sm{font-size:.7rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-label{font-family:var(--font-mono);font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}
.form-input{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);padding:.62rem .88rem;font-family:var(--font-body);font-size:.82rem;font-weight:300;outline:none;transition:border-color .25s}
.form-input:focus{border-color:var(--gold-border)}
.form-input::placeholder{color:var(--text-muted)}
.form-select{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);padding:.62rem .88rem;font-family:var(--font-body);font-size:.82rem;outline:none;transition:border-color .25s;appearance:none;cursor:pointer}
.form-select:focus{border-color:var(--gold-border)}
.form-textarea{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);padding:.62rem .88rem;font-family:var(--font-body);font-size:.82rem;font-weight:300;outline:none;transition:border-color .25s;resize:vertical;min-height:120px}
.form-textarea:focus{border-color:var(--gold-border)}
.form-textarea::placeholder{color:var(--text-muted)}
.form-btn{background:var(--gold);border:none;color:var(--bg-primary);padding:.78rem;font-family:var(--font-mono);font-size:.7rem;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:all .25s;margin-top:.5rem}
.form-btn:hover{background:var(--gold-light)}
.form-btn:disabled{opacity:.35;cursor:not-allowed}
.form-btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:.78rem;font-family:var(--font-mono);font-size:.7rem;cursor:pointer;transition:all .25s}
.form-btn-secondary:hover{border-color:var(--gold-border);color:var(--gold)}
.form-link{text-align:center;color:var(--text-secondary);font-size:.76rem;margin-top:.5rem}
.form-link a{color:var(--gold);text-decoration:none;cursor:pointer}
.form-link a:hover{text-decoration:underline}
.form-hint{font-size:.68rem;color:var(--text-muted);margin-top:.25rem}
.password-wrap{position:relative;display:flex}
.password-wrap .form-input{padding-right:2.6rem;width:100%}
.pw-toggle{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--text-muted);padding:0;transition:color .2s}
.pw-toggle:hover{color:var(--gold)}
.pw-strength-bar{height:2px;background:var(--bg-primary);border:1px solid var(--border);margin-top:.35rem;overflow:hidden}
.pw-strength-fill{height:100%;width:0;transition:width .4s,background .4s}
.pw-strength-label{font-family:var(--font-mono);font-size:.6rem;margin-top:.2rem;display:block;min-height:.85rem}
.field-error{font-size:.64rem;color:#c0392b;font-family:var(--font-mono);min-height:.85rem;display:block}
.checkbox-label{display:flex;gap:.6rem;align-items:flex-start;font-size:.76rem;color:var(--text-secondary);cursor:pointer;line-height:1.5;font-weight:300}
.checkbox-label input[type=checkbox]{accent-color:var(--gold);width:13px;height:13px;margin-top:2px;flex-shrink:0;cursor:pointer}
.checkbox-label a{color:var(--gold)}
.checkbox-label.sm{font-size:.72rem}
.btn-full{width:100%}
.verified-badge{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-mono);font-size:.6rem;color:#4caf50;background:rgba(76,175,80,.08);border:1px solid rgba(76,175,80,.2);padding:.12rem .55rem;margin-top:.3rem}
.unverified-badge{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-mono);font-size:.6rem;color:#f0a500;background:rgba(240,165,0,.08);border:1px solid rgba(240,165,0,.2);padding:.12rem .55rem;margin-top:.3rem}
.verify-notice{margin-top:1rem;padding:.75rem 1rem;background:rgba(240,165,0,.06);border:1px solid rgba(240,165,0,.2);font-size:.76rem;color:#f0a500;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.verify-notice .link-btn{color:#f0a500}
.verify-pending{text-align:center;padding:.5rem 0}
.verify-icon{font-size:2.5rem;margin-bottom:.8rem}
.verify-title{font-family:var(--font-display);font-size:1.2rem;font-weight:400;font-style:italic;margin-bottom:.5rem}
.verify-sub{font-size:.8rem;color:var(--text-secondary);line-height:1.75;margin-bottom:1.2rem;font-weight:300}
.verify-sub strong{color:var(--text-primary)}
.verify-demo-notice{background:var(--gold-dim);border:1px solid var(--gold-border);padding:.75rem 1rem;margin-bottom:1.2rem;text-align:left}
.verify-demo-label{font-family:var(--font-mono);font-size:.6rem;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:.4rem}
.verify-code-display{display:block;font-family:var(--font-mono);font-size:.72rem;color:var(--text-primary);word-break:break-all;line-height:1.6}
.verify-code-input{text-align:center;font-family:var(--font-mono);font-size:.88rem;letter-spacing:.05em}
.profile-view{display:flex;flex-direction:column;gap:1.5rem}
.profile-header{display:flex;gap:1rem;align-items:flex-start}
.profile-avatar{width:48px;height:48px;background:var(--gold-dim);border:1px solid var(--gold-border);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.3rem;font-weight:500;color:var(--gold);flex-shrink:0}
.profile-info{display:flex;flex-direction:column;gap:.2rem}
.profile-name{font-family:var(--font-display);font-size:1rem;font-weight:500}
.profile-email{font-size:.74rem;color:var(--text-secondary)}
.profile-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem;background:var(--bg-primary);border:1px solid var(--border)}
.profile-stat{text-align:center}
.profile-stat-num{font-family:var(--font-display);font-size:1.85rem;font-weight:400;font-style:italic;display:block;color:var(--gold)}
.profile-stat-label{font-family:var(--font-mono);font-size:.58rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}
.logout-btn{padding:.58rem 1.2rem;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;cursor:pointer;transition:all .25s;text-align:center;text-transform:uppercase}
.logout-btn:hover{border-color:rgba(192,57,43,.3);color:#c0392b}
.profile-section-title{font-family:var(--font-mono);font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;padding-bottom:.8rem;border-bottom:1px solid var(--border);margin-bottom:1rem}
.purchase-list,.review-list{display:flex;flex-direction:column;gap:.8rem}
.purchase-item{background:var(--bg-primary);border:1px solid var(--border);padding:.9rem;display:flex;flex-direction:column;gap:.35rem}
.purchase-name{font-size:.82rem;font-weight:500}
.purchase-meta{display:flex;justify-content:space-between;align-items:center}
.purchase-date{font-family:var(--font-mono);font-size:.62rem;color:var(--text-muted)}
.purchase-price{font-family:var(--font-display);font-size:.9rem;font-style:italic;color:var(--gold)}
.purchase-id{font-family:var(--font-mono);font-size:.58rem;color:var(--text-muted)}
.purchase-download{background:transparent;border:1px solid var(--gold-border);color:var(--gold);padding:.22rem .72rem;font-family:var(--font-mono);font-size:.6rem;cursor:pointer;transition:all .25s;margin-top:.15rem;align-self:flex-start}
.purchase-download:hover{background:var(--gold-dim)}
.review-item{background:var(--bg-primary);border:1px solid var(--border);padding:.9rem;display:flex;flex-direction:column;gap:.3rem}
.review-product{font-size:.8rem;font-weight:500}
.review-rating{color:var(--gold);font-size:.74rem}
.review-text{font-size:.76rem;color:var(--text-secondary);line-height:1.7;font-weight:300}
.review-date{font-family:var(--font-mono);font-size:.6rem;color:var(--text-muted)}
.review-delete{align-self:flex-start;background:none;border:1px solid var(--border);color:var(--text-muted);padding:.18rem .55rem;font-size:.64rem;cursor:pointer;transition:all .25s}
.review-delete:hover{border-color:rgba(192,57,43,.3);color:#c0392b}
.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--text-muted)}
.empty-state-icon{font-size:1.8rem;margin-bottom:.5rem}
.empty-state p{font-family:var(--font-display);font-style:italic;font-size:.88rem}

/* ════════════════════════════════════════
   GUMROAD ORDER MODAL
════════════════════════════════════════ */
.order-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.93);backdrop-filter:blur(8px);z-index:5000;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .35s}
.order-modal-overlay.open{opacity:1;pointer-events:auto}
.order-modal{background:var(--bg-secondary);width:100%;max-width:480px;max-height:92vh;overflow-y:auto;border:1px solid var(--border);display:flex;flex-direction:column;transform:translateY(18px) scale(.97);transition:transform .35s cubic-bezier(.16,1,.3,1)}
.order-modal-overlay.open .order-modal{transform:translateY(0) scale(1)}
.order-modal-header{padding:1.3rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.order-modal-title{font-family:var(--font-display);font-size:1rem;font-weight:400;font-style:italic}
.order-modal-close{background:none;border:1px solid var(--border);color:var(--text-muted);font-size:.78rem;cursor:pointer;width:26px;height:26px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.order-modal-close:hover{border-color:var(--gold-border);color:var(--gold)}
.order-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.2rem}
.order-items{display:flex;flex-direction:column;gap:.5rem}
.order-item{display:flex;gap:.8rem;align-items:center;padding:.62rem;background:var(--bg-tertiary);border:1px solid var(--border)}
.gm-item{align-items:flex-start}
.order-item-img{width:38px;height:38px;flex-shrink:0;overflow:hidden;background:var(--bg-primary);border:1px solid var(--border)}
.order-item-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.55)}
.order-item-info{flex:1;min-width:0}
.order-item-name{font-size:.8rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.1rem}
.order-item-type{font-family:var(--font-mono);font-size:.56rem;color:var(--text-muted);text-transform:uppercase}
.order-item-price{font-family:var(--font-display);font-size:.88rem;font-style:italic;color:var(--gold);white-space:nowrap}
.gm-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0}
.gm-buy-btn{display:inline-block;padding:.26rem .7rem;background:var(--gold);border:none;color:var(--bg-primary);font-family:var(--font-mono);font-size:.6rem;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all .2s;letter-spacing:.05em}
.gm-buy-btn:hover{background:var(--gold-light)}
.gm-unavail{font-family:var(--font-mono);font-size:.58rem;color:var(--text-muted);white-space:nowrap}
.order-totals{border-top:1px solid var(--border);padding:.72rem 0;display:flex;flex-direction:column;gap:.35rem}
.order-total-row{display:flex;justify-content:space-between;font-size:.76rem;color:var(--text-muted)}
.order-total-row.total{font-family:var(--font-display);font-size:.95rem;color:var(--text-secondary);padding-top:.5rem;border-top:1px solid var(--border)}
.order-total-row.total span:last-child{color:var(--gold);font-style:italic}
.gm-notice{display:flex;gap:.65rem;align-items:flex-start;background:var(--gold-dim);border:1px solid var(--gold-border);padding:.82rem 1rem;font-size:.74rem;color:var(--text-muted);line-height:1.6}
.gm-notice-icon{font-family:var(--font-mono);font-size:.82rem;color:var(--gold);flex-shrink:0}
.gm-notice strong{color:var(--text-secondary)}
.gm-branding{display:flex;flex-direction:column;gap:.5rem;border-top:1px solid var(--border);padding-top:.8rem}
.gm-brand-logo{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.6rem;color:var(--text-muted)}
.gm-brand-points{display:flex;flex-direction:column;gap:.2rem}
.gm-brand-points span{font-family:var(--font-mono);font-size:.58rem;color:var(--text-muted);display:flex;align-items:center;gap:.35rem}
.pay-submit{width:100%;padding:.78rem;background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-mono);font-size:.7rem;cursor:pointer;transition:all .25s;letter-spacing:.08em}
.pay-submit:hover{background:var(--bg-elevated);color:var(--text-secondary)}
.success-modal{overflow:hidden}
.success-modal-header{background:linear-gradient(135deg,var(--gold-dim),rgba(8,8,8,.5));border-bottom:1px solid var(--gold-border);padding:2rem 1.5rem;text-align:center}
.success-checkmark{width:50px;height:50px;border:1px solid var(--gold-border);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .8rem;font-size:1.2rem;color:var(--gold)}
.success-title{font-family:var(--font-display);font-size:1.1rem;font-weight:400;font-style:italic;margin-bottom:.3rem}
.success-sub{font-size:.76rem;color:var(--text-secondary);line-height:1.75}
.cart-secure-line{display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.56rem;color:var(--text-muted);padding:.4rem 0;letter-spacing:.07em}
.cart-secure-dot{width:4px;height:4px;border-radius:50%;background:var(--text-muted);flex-shrink:0}

/* ════════════════════════════════════════
   MISC / UTILITIES
════════════════════════════════════════ */
.alert{padding:.88rem 1.1rem;border:1px solid;font-size:.8rem;margin-bottom:1rem;font-weight:300}
.alert-success{border-color:rgba(76,175,80,.22);background:rgba(76,175,80,.05);color:#4caf50}
.alert-error{border-color:rgba(192,57,43,.22);background:rgba(192,57,43,.05);color:#c0392b}
.alert-info{border-color:var(--gold-border);background:var(--gold-dim);color:var(--gold)}

.breadcrumb{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.62rem;color:var(--text-muted);margin-bottom:1rem}
.breadcrumb a{color:var(--text-muted);text-decoration:none;transition:color .25s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:var(--text-muted)}

.card{background:var(--bg-secondary);border:1px solid var(--border);padding:2rem;transition:border-color .3s}
.card:hover{border-color:var(--gold-border)}
.card-title{font-family:var(--font-display);font-size:1.1rem;font-weight:400;font-style:italic;margin-bottom:.5rem}
.card-text{color:var(--text-secondary);font-size:.82rem;line-height:1.75;font-weight:300}

.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.8rem}
th{font-family:var(--font-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);padding:.72rem 1rem;text-align:left;border-bottom:1px solid var(--border)}
td{padding:.72rem 1rem;border-bottom:1px solid rgba(242,237,232,.03);color:var(--text-secondary);font-weight:300}
tr:hover td{background:var(--bg-secondary);color:var(--text-primary)}

.pagination{display:flex;gap:.35rem;justify-content:center;margin-top:3rem}
.page-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-mono);font-size:.68rem;cursor:pointer;transition:all .25s}
.page-btn:hover,.page-btn.active{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .85s ease,transform .85s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* reCAPTCHA */
.grecaptcha-badge{opacity:.25!important;transition:opacity .3s}
.grecaptcha-badge:hover{opacity:.7!important}

/* Logo image */
.site-logo-img{height:36px;width:auto;max-width:190px;object-fit:contain;display:block;flex-shrink:0;background:transparent}
.footer-logo-img{height:auto;max-height:48px;width:auto;max-width:220px;object-fit:contain;display:block;background:transparent}
.logo-icon,.logo-text{display:none}

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media(max-width:1200px){
  .skills-grid{grid-template-columns:repeat(2,1fr)}
  .skills-grid .skill-card:nth-child(3n){border-right:1px solid var(--border)}
  .skills-grid .skill-card:nth-child(2n){border-right:none}
  .footer-grid{grid-template-columns:2fr 1fr 1fr}
  .footer-brand{grid-column:1/-1;max-width:100%}
  .hc-card{flex:0 0 33.333%}
}
@media(max-width:1000px){
  .mp-grid{grid-template-columns:repeat(2,1fr)}
  .mp-fc-track{height:auto}
  .mp-fc-slide{position:relative;grid-template-columns:1fr;height:auto}
  .mp-fc-visual{height:220px}
}
@media(max-width:900px){
  .mp-featured{grid-template-columns:1fr}
  .mp-featured-visual{height:220px}
  .modal-hero{grid-template-columns:1fr}
  .project-card{grid-template-columns:1fr;min-height:auto}
  .project-card:nth-child(even){direction:ltr}
  .project-card:nth-child(even) .project-info{border-right:none;border-left:1px solid var(--border)}
  .project-image{height:240px}
  .hc-card{flex:0 0 50%}
}
@media(max-width:768px){
  header{padding:1.1rem 1.4rem}
  nav{position:fixed;top:66px;left:0;right:0;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-direction:column;gap:0;align-items:stretch;transform:translateY(-100%);opacity:0;transition:transform .3s,opacity .3s;pointer-events:none}
  nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
  nav a,.nav-cart{padding:1rem 1.4rem;border-bottom:1px solid var(--border);justify-content:center}
  nav a::after{display:none}
  .menu-toggle{display:block}
  .section{padding:5rem 1.4rem}
  .page-hero{padding:8rem 1.4rem 3.5rem}
  .stats{grid-template-columns:repeat(2,1fr)}
  .mp-grid{grid-template-columns:1fr}
  .mp-toolbar{flex-direction:column;align-items:stretch}
  .mp-search-wrap{max-width:100%;margin-left:0}
  .mp-newsletter{flex-direction:column;align-items:stretch;padding:2rem 1.5rem}
  .mp-newsletter-input{width:100%}
  .contact{padding:6rem 1.4rem}
  footer{padding:4rem 1.4rem 2.5rem}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-legal{justify-content:center}
  /* Hero mobile: reduce side padding, increase bottom so content clears dots/counter */
  .hero-slide-content{padding:0 1.4rem 7rem}
  .hero-slide-title{font-size:clamp(2.4rem,9vw,4rem)}
  .hero-slide-eyebrow{margin-bottom:1rem}
  .hero-slide-desc{font-size:.82rem;margin-bottom:1.5rem}
  .hero-slide-btns .btn{padding:.62rem 1.3rem;font-size:.62rem}
  .hero-prev{left:.8rem}
  .hero-next{right:.8rem}
  .hero-dots{left:1.4rem;bottom:3.2rem}
  .hero-counter{right:1.4rem;bottom:4.8rem}
  .skills-grid{grid-template-columns:1fr}
  .skills-grid .skill-card{border-right:none}
  .hc-card{flex:0 0 100%}
  .mp-main{padding:1.5rem 1.4rem 4rem}
}

/* ── Short-screen / landscape phone fix ── */
@media(max-width:768px) and (max-height:500px){
  .hero-slider{height:auto;min-height:100svh}
  .hero-slide-content{padding:0 1.4rem 5rem}
  .hero-slide-title{font-size:clamp(1.8rem,6vw,2.8rem)}
  .hero-slide-desc{display:none}
  .hero-dots{bottom:1.8rem}
  .hero-counter{bottom:3rem}
}

/* ── Very small phones (≤390px) ── */
@media(max-width:390px){
  .hero-slide-title{font-size:clamp(2.2rem,10vw,3.2rem)}
  .hero-slide-content{padding:0 1.1rem 7rem}
  .hero-slide-btns{flex-direction:column;align-items:flex-start}
  .hero-slide-btns .btn{width:auto}
}
