/* css/pages/workspace.css — full Pro Workspace styles.
   Lifted verbatim from fragra_ui.html lines 4444-4750 as part of
   the workspace UI port. Replaces the small gated-launcher CSS
   from Phase 4 part 1. The launcher landing card variants
   (.ws-landing, .ws-landing-card, .ws-eyebrow, etc.) stay so the
   guest / non-Pro paths still render. */

/* ── Old launcher landing card variants (kept for guest / non-Pro) ── */
.ws-landing{
  max-width:640px;margin:60px auto 80px;padding:0 24px;
  text-align:center;
}
.ws-landing-card{
  background:var(--card);
  border:1px solid rgba(184,150,78,0.18);
  border-radius:2px;
  padding:48px 36px 40px;
}
.ws-eyebrow{
  font-family:'Fraunces', Georgia, serif;
  font-size:10px;letter-spacing:3.5px;font-weight:600;
  color:#a08855;text-transform:uppercase;margin-bottom:14px;
}
.ws-title{
  font-family:'Fraunces', Georgia, serif;
  font-size:34px;font-weight:300;font-style:italic;
  letter-spacing:-0.6px;line-height:1.1;
  margin:0 0 12px;color:var(--ink);
}
.ws-divider{
  width:36px;height:1px;background:#a08855;
  margin:0 auto 22px;opacity:0.65;
}
.ws-body{
  font-size:14px;color:var(--muted);line-height:1.65;
  margin:0 auto 28px;max-width:480px;
}
.ws-meta-row{
  display:flex;justify-content:center;gap:18px;flex-wrap:wrap;
  font-family:'Fraunces', Georgia, serif;
  font-size:11px;letter-spacing:2.2px;font-weight:500;
  color:#a08855;text-transform:uppercase;
  margin:0 auto 28px;
}
.ws-meta-row .ws-meta-dot{opacity:0.5}
.ws-cta-row{
  display:inline-flex;gap:10px;flex-wrap:wrap;justify-content:center;
}
.ws-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;
  background:var(--ink);color:#fff;
  border:none;border-radius:0;
  font-family:inherit;
  font-size:11px;font-weight:600;
  letter-spacing:2.5px;text-transform:uppercase;
  cursor:pointer;text-decoration:none;
  transition:all .25s;
}
.ws-cta:hover{background:#a08855;transform:translateY(-1px)}
.ws-cta-arrow{font-size:13px;transition:transform .25s}
.ws-cta:hover .ws-cta-arrow{transform:translateX(3px)}
.ws-cta-ghost{
  background:transparent;color:var(--ink);
  border:1px solid rgba(184,150,78,0.30);
}
.ws-cta-ghost:hover{
  border-color:#a08855;color:var(--ink);
  background:rgba(184,150,78,0.04);
}
.ws-modules-preview{
  display:grid;grid-template-columns:repeat(auto-fill, minmax(160px, 1fr));
  gap:8px;margin:28px auto 0;max-width:520px;
  font-family:'Fraunces', Georgia, serif;
  font-size:11px;letter-spacing:1.6px;font-weight:500;
  color:#6f6052;text-transform:uppercase;
  text-align:left;
}
.ws-modules-preview div{
  padding:8px 12px;
  border:1px solid rgba(184,150,78,0.18);
  background:rgba(184,150,78,0.04);
}
.ws-loading{
  font-family:'Fraunces', Georgia, serif;
  font-size:13px;color:var(--muted);font-style:italic;
  padding:40px 0;
}

/* ── Artisan upgrade banner + gate badge (lines 4444-4514) ── */
    .artisan-gate{
      display:inline-flex;align-items:center;gap:4px;padding:3px 8px;
      border-radius:6px;background:var(--gold-soft);color:var(--gold2);
      font-size:10px;font-weight:700;letter-spacing:0.5px;cursor:pointer;
      transition:opacity .15s;
    }
    .artisan-gate:hover{opacity:0.8}
    .artisan-gate svg{width:12px;height:12px}

    /* Artisan upgrade banner */
    .artisan-banner{
      position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:200;
      background:var(--ink);color:#fff;padding:14px 24px;border-radius:16px;
      display:flex;align-items:center;gap:16px;
      box-shadow:0 8px 32px rgba(0,0,0,0.25);max-width:520px;width:calc(100% - 40px);
      animation:bannerSlideUp .4s ease-out;
    }
    @keyframes bannerSlideUp{from{transform:translateX(-50%) translateY(100px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}
    .artisan-banner-icon{font-size:28px;flex-shrink:0}
    .artisan-banner-text{flex:1}
    .artisan-banner-title{font-size:14px;font-weight:700;margin-bottom:2px}
    .artisan-banner-desc{font-size:12px;color:rgba(255,255,255,0.6);line-height:1.4}
    .artisan-banner-btn{
      padding:8px 18px;border-radius:10px;background:var(--gold);color:#fff;
      font-size:12px;font-weight:700;border:none;cursor:pointer;white-space:nowrap;
      transition:opacity .2s;
    }
    .artisan-banner-btn:hover{opacity:0.85}
    .artisan-banner-close{
      position:absolute;top:6px;right:10px;background:none;border:none;
      color:rgba(255,255,255,0.4);font-size:16px;cursor:pointer;padding:4px;
    }
    .artisan-banner-close:hover{color:#fff}

    /* ── Plans / Palette / Editor / Banner responsive ── */
    @media(max-width:768px){
      .plans-hero h2{font-size:clamp(22px, 5vw, 32px)}
      .plans-hero{padding:36px 16px 24px}
      .pal-ing-row{grid-template-columns:1fr 80px 70px 70px 32px;gap:6px}
      .fe-row{grid-template-columns:1fr 60px 70px 60px 32px;gap:6px}
      .artisan-banner{max-width:440px;padding:12px 18px;gap:12px}
      .artisan-banner-icon{font-size:22px}
      .artisan-banner-title{font-size:13px}
      .artisan-banner-desc{font-size:11px}
    }
    @media(max-width:600px){
      .plans-hero h2{font-size:22px}
      .plans-hero p{font-size:13px}
      .plan-card{padding:24px 18px 22px;border-radius:16px}
      .plan-name{font-size:20px}
      .plan-price{font-size:30px}
      .plan-desc{font-size:12px;min-height:auto}
      .plan-cta{padding:12px;font-size:13px}
      .pal-ing-row{grid-template-columns:1fr 60px 60px 60px 28px;gap:4px;font-size:11px}
      .fe-row{grid-template-columns:1fr 50px 60px 50px 28px;gap:4px;font-size:11px}
      .constraint-row{flex-wrap:wrap;gap:6px}
      .artisan-banner{flex-direction:column;text-align:center;padding:14px 16px;gap:10px;max-width:calc(100% - 24px)}
      .artisan-banner-btn{width:100%}
      .artisan-banner-close{top:4px;right:6px}
    }
    @media(max-width:400px){
      .plans-hero h2{font-size:20px}
      .plans-hero{padding:28px 12px 20px}
      .plan-card{padding:20px 14px 18px}
      .plan-name{font-size:18px}
      .plan-price{font-size:26px}
      .plan-feature{font-size:12px}
      .pal-ing-row{grid-template-columns:1fr 50px 50px 50px 24px;gap:3px;font-size:10px}
      .fe-row{grid-template-columns:1fr 44px 50px 44px 24px;gap:3px;font-size:10px}
      .artisan-banner{max-width:100%;border-radius:12px;bottom:12px}
    }

/* ── PRO WORKSPACE — three-column layout + sidebar + module + inspector (4516-4750) ── */
    /* ═══════════════════════════════════════════════════════════════
       PRO WORKSPACE — Three-column layout (sidebar + canvas + inspector)
       ═══════════════════════════════════════════════════════════════ */

    /* Hide consumer nav & hero when workspace is active */
    body.ws-active nav[aria-label="Main navigation"]{display:none}
    body.ws-active .hero{display:none!important}
    body.ws-active .artisan-banner{display:none!important}
    body.ws-active .lava-wrap{display:none}

    /* Top bar inside workspace */
    .ws-topbar{
      position:sticky;top:0;z-index:90;
      display:flex;align-items:center;gap:12px;
      height:52px;padding:0 20px;
      background:rgba(250,249,247,0.92);backdrop-filter:blur(20px);
      border-bottom:1px solid var(--line);
    }
    .ws-topbar-logo{
      display:flex;align-items:center;gap:2px;
      font-size:15px;font-weight:500;color:var(--ink);cursor:pointer;
      letter-spacing:-0.3px;margin-right:auto;
    }
    .ws-topbar-logo span{font-weight:300}
    .ws-topbar-breadcrumb{
      flex:1;display:flex;align-items:center;gap:6px;
      font-size:13px;color:var(--muted);
    }
    .ws-topbar-breadcrumb .ws-bc-sep{color:var(--muted2);font-size:10px}
    .ws-topbar-breadcrumb .ws-bc-current{color:var(--ink);font-weight:600}
    .ws-topbar-actions{
      display:flex;align-items:center;gap:8px;
    }
    .ws-topbar-exit{
      padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;
      background:var(--accent-soft);color:var(--ink);border:none;cursor:pointer;
      transition:background .15s;
    }
    .ws-topbar-exit:hover{background:rgba(17,17,17,0.10)}

    /* Main workspace container (fills viewport below topbar) */
    .ws-layout{
      display:grid;
      grid-template-columns:220px 1fr 280px;
      grid-template-rows:1fr;
      height:calc(100vh - 52px);
      overflow:hidden;
    }
    /* Collapsed inspector */
    .ws-layout.ws-inspector-collapsed{
      grid-template-columns:220px 1fr 0px;
    }

    /* ── Sidebar ── */
    .ws-sidebar{
      background:var(--card);
      border-right:1px solid var(--line);
      display:flex;flex-direction:column;
      overflow-y:auto;
      padding:12px 0;
    }
    .ws-sidebar::-webkit-scrollbar{width:4px}
    .ws-sidebar::-webkit-scrollbar-thumb{background:var(--line2);border-radius:2px}

    .ws-sidebar-section{
      padding:6px 16px 4px;font-size:9px;font-weight:700;
      letter-spacing:1px;text-transform:uppercase;color:var(--muted2);
      margin-top:8px;
    }
    .ws-sidebar-item{
      display:flex;align-items:center;gap:10px;
      padding:9px 16px;margin:1px 8px;border-radius:10px;
      font-size:13px;font-weight:500;color:var(--ink2);
      cursor:pointer;transition:all .15s;
      border:none;background:none;width:calc(100% - 16px);text-align:left;
    }
    .ws-sidebar-item:hover{background:var(--accent-soft);color:var(--ink)}
    .ws-sidebar-item.active{
      background:var(--ink);color:#fff;
      box-shadow:0 2px 8px rgba(0,0,0,0.12);
    }
    .ws-sidebar-item.active svg{stroke:#fff}
    .ws-sidebar-item svg{
      width:18px;height:18px;flex-shrink:0;
      stroke:var(--muted);stroke-width:1.8;fill:none;
    }
    .ws-sidebar-item.active svg{stroke:rgba(255,255,255,0.85)}
    .ws-sidebar-badge{
      margin-left:auto;font-size:9px;font-weight:700;
      padding:1px 6px;border-radius:4px;
      background:var(--gold-soft);color:var(--gold2);
    }
    .ws-sidebar-divider{
      height:1px;background:var(--line);margin:8px 16px;
    }

    /* ── Canvas (main working area) ── */
    .ws-canvas{
      overflow-y:auto;padding:28px 32px;
      background:var(--bg);
    }
    .ws-canvas::-webkit-scrollbar{width:6px}
    .ws-canvas::-webkit-scrollbar-thumb{background:var(--line2);border-radius:3px}

    .ws-module{display:none}
    .ws-module.active{display:block}

    /* Module header */
    .ws-module-header{
      display:flex;align-items:center;gap:12px;margin-bottom:24px;
    }
    .ws-module-header h2{
      font-size:22px;font-weight:700;letter-spacing:-0.5px;
    }
    .ws-module-header .ws-module-desc{
      font-size:13px;color:var(--muted);margin-left:auto;
    }

    /* Placeholder module content */
    .ws-placeholder{
      display:flex;flex-direction:column;align-items:center;justify-content:center;
      min-height:300px;gap:16px;
      border:2px dashed var(--line2);border-radius:20px;
      background:var(--accent-soft);
    }
    .ws-placeholder svg{width:48px;height:48px;stroke:var(--muted2);stroke-width:1.5;fill:none}
    .ws-placeholder p{font-size:14px;color:var(--muted);text-align:center;max-width:320px;line-height:1.6}
    .ws-placeholder .ws-ph-title{font-size:16px;font-weight:600;color:var(--ink2)}

    /* ── Inspector (right panel) ── */
    .ws-inspector{
      background:var(--card);
      border-left:1px solid var(--line);
      overflow-y:auto;
      display:flex;flex-direction:column;
      transition:width .2s;
    }
    .ws-inspector::-webkit-scrollbar{width:4px}
    .ws-inspector::-webkit-scrollbar-thumb{background:var(--line2);border-radius:2px}
    .ws-layout.ws-inspector-collapsed .ws-inspector{
      width:0;overflow:hidden;padding:0;border:none;
    }
    .ws-inspector-header{
      padding:16px 16px 12px;
      border-bottom:1px solid var(--line);
      display:flex;align-items:center;justify-content:space-between;
    }
    .ws-inspector-header h4{font-size:12px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;color:var(--muted)}
    .ws-inspector-toggle{
      width:24px;height:24px;border-radius:6px;border:none;
      background:var(--accent-soft);cursor:pointer;display:flex;align-items:center;justify-content:center;
      transition:background .15s;
    }
    .ws-inspector-toggle:hover{background:var(--line2)}
    .ws-inspector-toggle svg{width:14px;height:14px;stroke:var(--muted);stroke-width:2;fill:none}

    .ws-inspector-body{padding:16px;flex:1}

    /* Inspector cards */
    .ws-insp-card{
      background:var(--bg);border-radius:12px;padding:14px;
      margin-bottom:12px;
    }
    .ws-insp-card-title{
      font-size:11px;font-weight:700;letter-spacing:0.3px;
      text-transform:uppercase;color:var(--muted);margin-bottom:8px;
    }
    .ws-insp-row{
      display:flex;justify-content:space-between;align-items:center;
      font-size:12px;padding:3px 0;
    }
    .ws-insp-row .ws-insp-label{color:var(--ink2)}
    .ws-insp-row .ws-insp-value{font-weight:600;color:var(--ink)}

    /* Balance meter mini */
    .ws-insp-meter{
      height:6px;border-radius:3px;background:var(--line);margin-top:4px;overflow:hidden;
    }
    .ws-insp-meter-fill{height:100%;border-radius:3px;transition:width .3s}
    .ws-insp-meter-fill.top{background:var(--top-c)}
    .ws-insp-meter-fill.heart{background:var(--heart-c)}
    .ws-insp-meter-fill.base{background:var(--base-c)}

    /* Inspector warning/suggestion chips */
    .ws-insp-chip{
      display:flex;align-items:flex-start;gap:6px;
      font-size:11px;line-height:1.5;padding:6px 8px;
      border-radius:8px;margin-bottom:6px;
    }
    .ws-insp-chip.warn{background:var(--rose-soft);color:var(--rose)}
    .ws-insp-chip.info{background:var(--sage-soft);color:var(--sage)}
    .ws-insp-chip svg{width:14px;height:14px;flex-shrink:0;margin-top:1px}

    /* ── Responsive: collapse inspector on narrow screens ── */
    @media(max-width:1100px){
      .ws-layout{grid-template-columns:200px 1fr 0px}
      .ws-inspector{display:none}
    }
    @media(max-width:768px){
      .ws-layout{grid-template-columns:56px 1fr}
      .ws-sidebar-item span{display:none}
      .ws-sidebar-item{padding:10px;justify-content:center;margin:1px 4px}
      .ws-sidebar-section{display:none}
      .ws-sidebar-badge{display:none}
      .ws-sidebar-divider{margin:4px 8px}
      .ws-canvas{padding:16px}
      .ws-module-header{flex-direction:column;align-items:flex-start;gap:4px}
      .ws-module-header .ws-module-desc{margin-left:0;font-size:12px}
      .ws-topbar-breadcrumb{font-size:12px}
      .ws-topbar-actions .nav-name{display:none}
    }
    @media(max-width:600px){
      .ws-layout{grid-template-columns:44px 1fr}
      .ws-sidebar-item{padding:8px;margin:1px 2px}
      .ws-sidebar-item svg{width:16px;height:16px}
      .ws-canvas{padding:12px 10px}
      .ws-topbar{padding:0 10px;height:46px;gap:8px}
      .ws-topbar-logo{font-size:13px}
      .ws-topbar-exit{padding:5px 10px;font-size:11px}
      .ws-topbar-breadcrumb .ws-bc-sep,.ws-topbar-breadcrumb .ws-bc-current{font-size:11px}
      .ws-module-header h2{font-size:18px}
      .ws-layout{height:calc(100vh - 46px)}
      .ws-two-col{grid-template-columns:1fr !important}
      .ws-stat-grid{grid-template-columns:repeat(2,1fr) !important}
      .ws-data-table{overflow-x:auto !important;-webkit-overflow-scrolling:touch}
      .ws-placeholder{min-height:200px;padding:20px}
      .ws-placeholder p{font-size:13px}
    }
    @media(max-width:400px){
      .ws-layout{grid-template-columns:0 1fr}
      .ws-sidebar{display:none}
      .ws-canvas{padding:10px 8px}
      .ws-topbar-logo{font-size:12px}
      .ws-stat-grid{grid-template-columns:1fr !important}
    }

/* ── /workspace MPA chrome adjustments ─────────────────────────
   Hide the shared MPA footer when in workspace (cleaner app feel).
   The shared nav + lava are already hidden via body.ws-active rules
   lifted above. */
body.ws-active footer.site-footer{display:none}
body.ws-active main#page-content{padding:0;margin:0;max-width:none}
