:root {
  --forest: #063b24;
  --green: #0f7a3a;
  --leaf: #22a35a;
  --mint: #a7f3d0;
  --cream: #faf7ef;
  --cream-2: #f1eadb;
  --gold: #d6a93a;
  --gold-2: #f4c542;
  --charcoal: #10251a;
  --muted: #5e6f64;
  --line: rgba(16, 37, 26, .12);
  --shadow: 0 24px 70px rgba(6, 59, 36, .16);
  --shadow-soft: 0 12px 35px rgba(6, 59, 36, .10);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--charcoal);
  background: var(--cream);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }

.section-inner { width: min(1440px, calc(100% - clamp(32px, 5vw, 96px))); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 80; background: rgba(250,247,239,.82); border-bottom: 1px solid rgba(6,59,36,.10); backdrop-filter: blur(18px); transition: all .25s ease; }
.site-header.scrolled { background: rgba(250,247,239,.96); box-shadow: 0 18px 50px rgba(6,59,36,.12); }
.nav-shell { width: min(1600px, calc(100% - clamp(28px, 4vw, 80px))); height: 82px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.brand-lockup { display: inline-flex; align-items: center; gap: 12px; min-width: 244px; }
.brand-mark { width: 48px; height: 48px; border-radius: 16px; display: grid; place-items: center; background: radial-gradient(circle at 28% 22%, #3bd06f, var(--green) 46%, var(--forest)); box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 16px 28px rgba(6,59,36,.22); position: relative; overflow: hidden; }
.brand-mark:after { content: ""; position: absolute; width: 34px; height: 18px; border: 2px solid rgba(244,197,66,.72); border-left: 0; border-bottom: 0; transform: rotate(-34deg); border-radius: 50%; top: 18px; left: 15px; }
.brand-mark span { color: white; font-weight: 900; letter-spacing: .03em; position: relative; z-index: 1; }
.brand-lockup strong { display: block; font-size: .94rem; line-height: 1.05; letter-spacing: -.01em; }
.brand-lockup small { display: block; color: var(--muted); font-size: .72rem; margin-top: 4px; }
.brand-lockup.light small, .brand-lockup.light strong { color: white; }
.desktop-nav { display: flex; align-items: center; gap: 6px; font-size: .82rem; font-weight: 800; color: rgba(16,37,26,.78); }
.desktop-nav > a, .nav-menu-trigger { padding: 10px 12px; border-radius: 999px; transition: .2s ease; white-space: nowrap; }
.desktop-nav a:hover, .desktop-nav a.active, .nav-menu-trigger:hover, .nav-menu-trigger.active, .nav-menu.open .nav-menu-trigger { color: var(--forest); background: rgba(15,122,58,.10); }
.nav-menu { position: relative; }
.nav-menu-trigger { display: inline-flex; align-items: center; gap: 9px; border: 0; color: rgba(16,37,26,.78); background: transparent; font-weight: 900; cursor: pointer; }
.nav-menu-trigger .chevron { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; border-radius: 999px; color: var(--green); font-size: 1rem; line-height: 1; transform: translateY(-1px); transition: transform .18s ease, background .18s ease; }
.nav-menu:hover .nav-menu-trigger .chevron, .nav-menu:focus-within .nav-menu-trigger .chevron, .nav-menu.open .nav-menu-trigger .chevron { transform: rotate(180deg); background: rgba(15,122,58,.10); }
.nav-menu-panel { display: grid; gap: 6px; position: absolute; right: 0; top: calc(100% + 12px); min-width: 295px; padding: 12px; border: 1px solid rgba(255,255,255,.66); background: rgba(250,247,239,.96); backdrop-filter: blur(18px); border-radius: 22px; box-shadow: var(--shadow); opacity: 0; visibility: hidden; transform: translateY(8px); transition: opacity .18s ease, transform .18s ease, visibility .18s ease; }
.nav-menu:hover .nav-menu-panel, .nav-menu:focus-within .nav-menu-panel, .nav-menu.open .nav-menu-panel { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-menu-panel:before { content: ""; position: absolute; top: -8px; right: 28px; width: 16px; height: 16px; transform: rotate(45deg); background: rgba(250,247,239,.96); border-left: 1px solid rgba(255,255,255,.66); border-top: 1px solid rgba(255,255,255,.66); }
.nav-menu-panel a { position: relative; z-index: 1; display: block; padding: 12px 13px; border-radius: 16px; color: var(--charcoal); }
.nav-menu-panel a:hover, .nav-menu-panel a:focus { background: rgba(15,122,58,.09); outline: 0; }
.nav-menu-panel strong { display: block; font-size: .86rem; font-weight: 950; }
.nav-menu-panel small { display: block; margin-top: 3px; color: var(--muted); font-size: .72rem; line-height: 1.35; font-weight: 750; }
.nav-actions { display: flex; align-items: center; gap: 10px; }
.quote-btn, .btn-primary { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 42px; padding: 0 18px; border: 0; border-radius: 999px; color: white; background: linear-gradient(135deg, var(--green), var(--forest)); font-weight: 900; box-shadow: 0 16px 34px rgba(6,59,36,.22); cursor: pointer; transition: transform .2s ease, box-shadow .2s ease; }
.quote-btn:hover, .btn-primary:hover { transform: translateY(-2px); box-shadow: 0 22px 45px rgba(6,59,36,.28); }
.marketplace-cta { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 0 20px; border-radius: 999px; color: #1f1a0d; background: linear-gradient(135deg, var(--gold-2), var(--gold)); font-weight: 950; box-shadow: 0 18px 38px rgba(93,68,11,.20); transition: transform .2s ease, box-shadow .2s ease; white-space: nowrap; }
.marketplace-cta:hover { transform: translateY(-2px); box-shadow: 0 22px 46px rgba(93,68,11,.28); }
.login-btn { min-height: 40px; padding: 0 15px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; border: 1px solid rgba(6,59,36,.18); color: var(--forest); background: rgba(255,255,255,.58); font-weight: 900; }
.nav-logout-form, .mobile-logout-form { margin: 0; }
.logout-btn { cursor: pointer; }
.btn-secondary { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 0 18px; border-radius: 999px; border: 1px solid rgba(255,255,255,.42); color: white; font-weight: 900; background: rgba(255,255,255,.08); backdrop-filter: blur(10px); }
.btn-cream { color: var(--forest); background: var(--cream); border-color: transparent; box-shadow: 0 16px 32px rgba(0,0,0,.12); }
.btn-gold { color: #1f1a0d; background: linear-gradient(135deg, var(--gold-2), var(--gold)); border-color: transparent; }
.mobile-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--line); background: white; border-radius: 14px; padding: 10px; }
.mobile-toggle span { display: block; height: 2px; background: var(--forest); margin: 5px 0; border-radius: 4px; }
.mobile-menu { display: none; width: min(1240px, calc(100% - 28px)); margin: 0 auto 14px; padding: 14px; border-radius: 22px; background: rgba(255,255,255,.9); box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.7); }
.mobile-menu-group { padding: 6px 0 12px; border-bottom: 1px solid rgba(6,59,36,.08); }
.mobile-menu-group:last-child { border-bottom: 0; padding-bottom: 0; }
.mobile-menu-group > span { display: block; padding: 8px 10px 4px; color: var(--muted); font-size: .68rem; font-weight: 950; letter-spacing: .12em; text-transform: uppercase; }
.mobile-menu a, .mobile-menu button { display: flex; width: 100%; min-height: 46px; align-items: center; padding: 12px 14px; border-radius: 14px; font-weight: 850; color: var(--forest); border: 0; background: transparent; text-align: left; }
.mobile-menu a:hover, .mobile-menu button:hover { background: rgba(15,122,58,.08); }
.mobile-collapse-trigger { justify-content: space-between; font-weight: 950 !important; }
.mobile-collapse-trigger span { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 999px; background: rgba(15,122,58,.10); font-size: 1.05rem; transition: transform .18s ease; }
.mobile-collapse.open .mobile-collapse-trigger span { transform: rotate(180deg); }
.mobile-collapse-panel { display: none; padding-left: 8px; }
.mobile-collapse.open .mobile-collapse-panel { display: block; }
.mobile-marketplace-group .marketplace-cta { width: 100%; min-height: 48px; }
.mobile-account-group .quote-btn { justify-content: center; color: white; background: linear-gradient(135deg, var(--green), var(--forest)); }
.mobile-account-group .login-btn { justify-content: center; background: rgba(250,247,239,.92); border: 1px solid rgba(6,59,36,.16); }
.mobile-menu.open { display: block; }
.marketplace-header { background: rgba(6,59,36,.92); border-bottom-color: rgba(255,255,255,.10); }
.marketplace-header.scrolled { background: rgba(6,59,36,.97); box-shadow: 0 18px 50px rgba(0,0,0,.20); }
.marketplace-header .brand-lockup strong, .marketplace-header .brand-lockup small { color: white; }
.marketplace-header .desktop-nav { color: rgba(255,255,255,.76); }
.marketplace-header .desktop-nav > a { color: rgba(255,255,255,.78); }
.marketplace-header .desktop-nav a:hover, .marketplace-header .desktop-nav a.active { color: white; background: rgba(255,255,255,.10); }
.marketplace-header .login-btn, .marketplace-back-link { min-height: 40px; padding: 0 14px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; border: 1px solid rgba(255,255,255,.18); color: white; background: rgba(255,255,255,.09); font-weight: 900; white-space: nowrap; }
.marketplace-back-link:hover, .marketplace-header .login-btn:hover { background: rgba(255,255,255,.15); }
.marketplace-header .mobile-toggle { background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.18); }
.marketplace-header .mobile-toggle span { background: white; }
.marketplace-mobile-menu { background: rgba(6,59,36,.96); border-color: rgba(255,255,255,.14); }
.marketplace-mobile-menu .mobile-menu-group { border-bottom-color: rgba(255,255,255,.12); }
.marketplace-mobile-menu .mobile-menu-group > span { color: rgba(255,255,255,.58); }
.marketplace-mobile-menu a, .marketplace-mobile-menu button { color: white; }
.marketplace-mobile-menu a:hover, .marketplace-mobile-menu button:hover { background: rgba(255,255,255,.10); }

.hero { position: relative; overflow: hidden; padding: 88px 0 64px; color: white; background: radial-gradient(circle at 70% 22%, rgba(34,163,90,.7), transparent 28%), linear-gradient(135deg, #032819, var(--forest) 54%, #0b5e32); }
.hero:before, .pattern:before { content: ""; position: absolute; inset: 0; opacity: .16; background-image: radial-gradient(circle at 20px 20px, rgba(255,255,255,.35) 1.5px, transparent 2px), linear-gradient(120deg, transparent 0 45%, rgba(255,255,255,.14) 46% 47%, transparent 48%); background-size: 42px 42px, 90px 90px; pointer-events: none; }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr .95fr; gap: 54px; align-items: center; }
.eyebrow { display: inline-flex; align-items: center; gap: 9px; padding: 8px 12px; border-radius: 999px; border: 1px solid rgba(214,169,58,.38); background: rgba(214,169,58,.14); color: #ffe7a2; font-size: .74rem; font-weight: 900; letter-spacing: .11em; text-transform: uppercase; }
.hero h1, .page-hero h1 { font-size: clamp(2.7rem, 6vw, 5.8rem); line-height: .95; letter-spacing: -.04em; margin: 18px 0 22px; max-width: 900px; }
.hero p, .page-hero p { color: rgba(255,255,255,.82); font-size: 1.08rem; line-height: 1.75; max-width: 650px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.trust-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.trust-row span, .pill { display: inline-flex; align-items: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.16); color: inherit; font-size: .75rem; font-weight: 900; }
.hero-visual { position: relative; min-height: 520px; perspective: 1200px; }
.hero-collage { min-height: 540px; }
.image-panel, .visual-panel { position: relative; overflow: hidden; border-radius: 34px; background: linear-gradient(145deg, rgba(255,255,255,.2), rgba(255,255,255,.06)); border: 1px solid rgba(255,255,255,.24); box-shadow: 0 30px 90px rgba(0,0,0,.28); }
.image-panel { min-height: 430px; padding: 20px; transform: rotateY(-7deg) rotateX(4deg); }
.hero-collage .image-panel { width: 78%; min-height: 410px; margin-left: auto; }
.collage-card { position: absolute; z-index: 3; overflow: hidden; border-radius: 26px; padding: 12px; background: rgba(250,247,239,.22); border: 1px solid rgba(255,255,255,.28); box-shadow: 0 24px 70px rgba(0,0,0,.28); backdrop-filter: blur(14px); }
.collage-card.tasting { width: 245px; height: 190px; left: 6px; bottom: 76px; animation: softFloat 6s ease-in-out infinite; }
.collage-card.leaves { width: 190px; height: 150px; right: 18px; top: 12px; animation: softFloat 7s ease-in-out infinite reverse; }
.photo-placeholder { min-height: 100%; border-radius: 26px; position: relative; overflow: hidden; background-image: linear-gradient(160deg, rgba(250,247,239,.88), rgba(167,243,208,.38)), radial-gradient(circle at 25% 18%, rgba(244,197,66,.82), transparent 13%), linear-gradient(145deg, #2a8b4c, #0b4229); background-size: cover; background-position: center; }
.photo-placeholder.has-image { background-image: linear-gradient(160deg, rgba(6,59,36,.18), rgba(6,59,36,.35)), var(--image), linear-gradient(145deg, #2a8b4c, #0b4229); }
.photo-placeholder:before { content: ""; position: absolute; inset: 12% -10% 0; background: repeating-linear-gradient(162deg, rgba(6,59,36,.45) 0 2px, transparent 2px 24px); transform: rotate(-4deg); opacity: .72; }
.photo-placeholder:after { content: attr(data-label); position: absolute; left: 22px; bottom: 22px; padding: 10px 14px; border-radius: 14px; color: white; background: rgba(6,59,36,.72); font-weight: 900; backdrop-filter: blur(12px); }
.floating-card { position: absolute; z-index: 2; padding: 14px 16px; border-radius: 18px; color: var(--charcoal); background: rgba(250,247,239,.9); box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.7); backdrop-filter: blur(16px); }
.floating-card strong { display: block; font-size: 1.55rem; line-height: 1; color: var(--forest); }
.floating-card small { color: var(--muted); font-weight: 800; }
.float-a { top: 28px; left: -12px; } .float-b { right: -10px; top: 165px; } .float-c { left: 28px; bottom: 20px; } .float-d { right: 30px; bottom: 75px; }
.operation-mini { right: 12px; bottom: 14px; }
.cert-mini { left: 72px; top: 38px; }
@keyframes softFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }

.section { padding: 82px 0; position: relative; }
.cream-band { background: var(--cream); }
.white-band { background: rgba(255,255,255,.72); }
.dark-band { color: white; background: linear-gradient(135deg, #032819, var(--forest)); }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 24px; margin-bottom: 30px; }
.section-heading.center { display: block; text-align: center; max-width: 780px; margin-inline: auto; }
.section-heading h2 { font-size: clamp(2rem, 4vw, 3.7rem); line-height: 1; letter-spacing: -.035em; margin: 10px 0 0; }
.section-heading p { max-width: 650px; color: var(--muted); line-height: 1.7; margin: 12px 0 0; }
.dark-band .section-heading p { color: rgba(255,255,255,.72); }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.premium-card { position: relative; overflow: hidden; border-radius: 28px; padding: 26px; background: rgba(255,255,255,.76); border: 1px solid rgba(255,255,255,.78); box-shadow: var(--shadow-soft); transition: transform .25s ease, box-shadow .25s ease; }
.premium-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.premium-card h3 { font-size: 1.22rem; font-weight: 900; margin: 10px 0 8px; }
.premium-card p { color: var(--muted); line-height: 1.65; }
.icon-badge { width: 46px; height: 46px; border-radius: 16px; display: grid; place-items: center; color: var(--forest); background: linear-gradient(145deg, #fff7dc, #dff8e9); border: 1px solid rgba(214,169,58,.28); font-weight: 950; }
.stat-card { padding: 24px; border-radius: 24px; background: linear-gradient(145deg, white, #f7f0dd); border: 1px solid rgba(214,169,58,.22); box-shadow: var(--shadow-soft); }
.stat-card strong { display: block; font-size: clamp(1.8rem, 4vw, 3rem); color: var(--forest); letter-spacing: -.045em; }
.stat-card span { display: block; color: var(--muted); font-weight: 850; margin-top: 4px; }
.product-card .product-art { height: 220px; border-radius: 24px; margin: -8px -8px 18px; background: radial-gradient(circle at 72% 18%, rgba(244,197,66,.82), transparent 12%), linear-gradient(145deg, #123c27, #1fa157); position: relative; overflow: hidden; }
.product-card .product-art:before { content: ""; position: absolute; inset: 24px; border-radius: 50%; border: 28px solid rgba(250,247,239,.86); box-shadow: inset 0 18px 30px rgba(6,59,36,.2); }
.product-card .product-art:after { content: attr(data-pack); position: absolute; left: 18px; bottom: 18px; padding: 9px 12px; border-radius: 12px; background: rgba(250,247,239,.9); color: var(--forest); font-weight: 950; font-size: .78rem; }
.product-meta { display: flex; gap: 8px; flex-wrap: wrap; margin: 12px 0; }
.product-meta span { font-size: .72rem; font-weight: 900; color: var(--forest); background: rgba(15,122,58,.1); border-radius: 999px; padding: 7px 10px; }
.card-actions { display: flex; gap: 10px; margin-top: 18px; flex-wrap: wrap; }
.card-actions .btn-primary, .card-actions .btn-secondary { min-height: 38px; font-size: .82rem; }
.card-actions .btn-secondary { color: var(--forest); border-color: rgba(6,59,36,.18); background: rgba(255,255,255,.58); }
.page-hero { position: relative; overflow: hidden; padding: 72px 0 104px; color: white; background: radial-gradient(circle at 80% 25%, rgba(214,169,58,.26), transparent 20%), linear-gradient(135deg, #032819, var(--forest)); }
.page-hero.marketplace-hero { background: radial-gradient(circle at 78% 28%, rgba(167,243,208,.30), transparent 22%), linear-gradient(135deg, #032819, #0b5830); }
.page-hero.specialty-hero { background: radial-gradient(circle at 82% 22%, rgba(214,169,58,.36), transparent 24%), linear-gradient(135deg, #102018, #5b4615); }
.page-hero.buyer-hero { background: radial-gradient(circle at 80% 25%, rgba(244,197,66,.26), transparent 20%), linear-gradient(135deg, #052116, #0f4a2b); }
.page-hero.sustainability-hero { background: radial-gradient(circle at 80% 25%, rgba(167,243,208,.32), transparent 22%), linear-gradient(135deg, #082a1b, #0f7a3a); }
.page-hero.news-hero { background: radial-gradient(circle at 80% 25%, rgba(214,169,58,.25), transparent 20%), linear-gradient(135deg, #051f16, #26371d); }
.page-hero.contact-hero { background: radial-gradient(circle at 80% 25%, rgba(255,255,255,.18), transparent 22%), linear-gradient(135deg, #032819, #145133); }
.page-hero.about-hero { background: radial-gradient(circle at 80% 25%, rgba(244,197,66,.20), transparent 20%), linear-gradient(135deg, #031f14, #0f6032); }
.hero-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.overlap-panel { margin-top: -74px; position: relative; z-index: 3; }
.filter-panel, .glass-panel { padding: 22px; border-radius: 28px; background: rgba(250,247,239,.82); border: 1px solid rgba(255,255,255,.72); box-shadow: var(--shadow); backdrop-filter: blur(18px); }
.filter-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr auto; gap: 14px; align-items: end; }
.field label { display: block; margin-bottom: 7px; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); font-weight: 950; }
.field input, .field select, .field textarea { width: 100%; border: 1px solid rgba(6,59,36,.16); background: rgba(255,255,255,.84); border-radius: 16px; padding: 13px 14px; outline: 0; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--green); box-shadow: 0 0 0 4px rgba(15,122,58,.12); }
.timeline { display: grid; gap: 14px; }
.timeline-item { display: grid; grid-template-columns: 44px 1fr; gap: 14px; align-items: start; }
.timeline-dot { width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; background: var(--forest); color: var(--gold-2); font-weight: 950; }
.news-card .news-art { height: 190px; margin: -8px -8px 18px; border-radius: 24px; background: linear-gradient(145deg, rgba(6,59,36,.92), rgba(34,163,90,.7)), repeating-linear-gradient(135deg, rgba(250,247,239,.28) 0 2px, transparent 2px 20px); position: relative; }
.leader-card { display: flex; gap: 14px; align-items: center; }
.avatar-mark { width: 52px; height: 52px; border-radius: 18px; display: grid; place-items: center; background: linear-gradient(145deg, var(--forest), var(--green)); color: var(--gold-2); font-weight: 950; flex: 0 0 auto; }
.map-placeholder { min-height: 360px; border-radius: 32px; background: linear-gradient(145deg, rgba(6,59,36,.86), rgba(34,163,90,.54)), repeating-linear-gradient(45deg, rgba(250,247,239,.18) 0 2px, transparent 2px 28px); display: grid; place-items: center; color: white; text-align: center; padding: 28px; box-shadow: var(--shadow); }

.dashboard-body { background: #071f16; color: #edf7ef; }
.portal-topbar { min-height: 82px; padding: 14px 24px; display: flex; align-items: center; justify-content: space-between; gap: 18px; border-bottom: 1px solid rgba(255,255,255,.08); background: rgba(5,26,18,.92); backdrop-filter: blur(16px); position: sticky; top: 0; z-index: 40; }
.portal-user { display: flex; align-items: center; gap: 12px; color: rgba(255,255,255,.75); font-weight: 850; }
.portal-user a, .portal-user button { border: 1px solid rgba(255,255,255,.14); color: white; background: rgba(255,255,255,.08); border-radius: 999px; padding: 9px 12px; cursor: pointer; }
.portal-hub { width: min(1180px, calc(100% - 32px)); margin: 0 auto; padding: 34px 0 70px; }
.dashboard-shell { display: grid; grid-template-columns: 268px 1fr; min-height: calc(100vh - 82px); }
.dash-sidebar { padding: 24px; border-right: 1px solid rgba(255,255,255,.08); background: linear-gradient(180deg, #051a12, #082a1b); }
.dash-sidebar a { display: block; padding: 12px 14px; border-radius: 14px; color: rgba(255,255,255,.72); font-weight: 850; margin-bottom: 6px; }
.dash-sidebar a.active, .dash-sidebar a:hover { color: white; background: rgba(214,169,58,.16); }
.dash-main { padding: 28px; }
.dash-topbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
.dash-topbar h1 { font-size: clamp(1.8rem, 3vw, 3rem); margin: 0; letter-spacing: -.035em; }
.dash-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px; }
.dash-card { border-radius: 24px; padding: 22px; background: linear-gradient(145deg, rgba(255,255,255,.11), rgba(255,255,255,.055)); border: 1px solid rgba(255,255,255,.11); box-shadow: 0 18px 50px rgba(0,0,0,.18); }
.span-3 { grid-column: span 3; } .span-4 { grid-column: span 4; } .span-5 { grid-column: span 5; } .span-6 { grid-column: span 6; } .span-7 { grid-column: span 7; } .span-8 { grid-column: span 8; } .span-12 { grid-column: span 12; }
.kpi-value { font-size: 2.2rem; font-weight: 950; color: #fff4c5; letter-spacing: -.04em; }
.trend { color: #a7f3d0; font-weight: 900; font-size: .82rem; }
.bar { height: 10px; border-radius: 999px; background: rgba(255,255,255,.1); overflow: hidden; }
.bar span { display: block; height: 100%; width: var(--w, 60%); background: linear-gradient(90deg, var(--gold), var(--mint)); border-radius: inherit; }
.chart-bars { display: flex; align-items: end; gap: 10px; height: 180px; padding-top: 20px; }
.chart-bars span { flex: 1; height: var(--h); min-height: 18px; border-radius: 12px 12px 4px 4px; background: linear-gradient(180deg, var(--mint), var(--green)); opacity: .95; }
.status-pill { display: inline-flex; padding: 6px 10px; border-radius: 999px; background: rgba(167,243,208,.14); color: #bdf7dc; font-size: .74rem; font-weight: 950; }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 12px; border-bottom: 1px solid rgba(255,255,255,.08); }
th { color: rgba(255,255,255,.58); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; }

.message-stack { position: fixed; right: 18px; top: 96px; z-index: 90; }
.toast-message { background: var(--forest); color: white; padding: 14px 18px; border-radius: 18px; box-shadow: var(--shadow); margin-bottom: 10px; }
.login-page { min-height: calc(100vh - 82px); display: grid; place-items: center; padding: 48px 16px; background: radial-gradient(circle at 75% 20%, rgba(34,163,90,.25), transparent 24%), linear-gradient(135deg, var(--cream), #e9f3e7); position: relative; overflow: hidden; }
.login-card { width: min(520px, 100%); padding: 34px; border-radius: 32px; background: rgba(250,247,239,.88); border: 1px solid rgba(255,255,255,.72); box-shadow: var(--shadow); backdrop-filter: blur(18px); position: relative; z-index: 1; }
.login-card h1 { font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1; letter-spacing: -.04em; margin: 14px 0 12px; color: var(--forest); }
.login-card p { color: var(--muted); line-height: 1.7; }
.login-card input { width: 100%; border: 1px solid rgba(6,59,36,.16); background: white; border-radius: 16px; padding: 13px 14px; outline: 0; }
.login-card input:focus { border-color: var(--green); box-shadow: 0 0 0 4px rgba(15,122,58,.12); }
.login-error { margin-top: 18px; padding: 12px 14px; border-radius: 16px; color: #6b1f14; background: #fff0ea; border: 1px solid #ffd0c2; font-weight: 800; }
.login-back { display: inline-block; margin-top: 18px; color: var(--forest); font-weight: 900; }
.footer { color: rgba(255,255,255,.76); background: linear-gradient(145deg, #031b12, var(--forest)); padding: 66px 0 24px; }
.footer-grid { display: grid; grid-template-columns: 1.7fr repeat(3, 1fr); gap: 30px; }
.footer h4 { color: white; font-weight: 950; margin: 0 0 14px; }
.footer a { display: block; margin: 10px 0; color: rgba(255,255,255,.76); }
.footer p { line-height: 1.7; }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; border-top: 1px solid rgba(255,255,255,.1); margin-top: 36px; padding-top: 20px; font-size: .86rem; }
.compact span { min-height: 26px; font-size: .68rem; }
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity: 1; transform: none; }

.home-hero { position: relative; overflow: hidden; padding: 86px 0 70px; color: white; background: radial-gradient(circle at 76% 18%, rgba(34,163,90,.34), transparent 24%), radial-gradient(circle at 16% 84%, rgba(214,169,58,.18), transparent 20%), linear-gradient(135deg, #031d13, #063b24 56%, #0c5a31); }
.home-hero:before { content: ""; position: absolute; inset: 0; opacity: .13; background-image: radial-gradient(circle at 22px 22px, rgba(255,255,255,.38) 1px, transparent 2px), repeating-linear-gradient(125deg, transparent 0 22px, rgba(255,255,255,.09) 23px 24px); background-size: 46px 46px, 96px 96px; pointer-events: none; }
.home-hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1fr) minmax(420px, .92fr); gap: 56px; align-items: center; }
.home-hero-copy h1 { font-size: clamp(2.65rem, 5.5vw, 5.45rem); line-height: .96; letter-spacing: -.045em; margin: 18px 0 20px; max-width: 820px; }
.home-hero-copy p { color: rgba(255,255,255,.82); font-size: 1.08rem; line-height: 1.75; max-width: 650px; }
.home-trust span { background: rgba(255,255,255,.09); color: rgba(255,255,255,.92); }
.home-hero-visual { min-height: 540px; position: relative; }
.hero-photo-main { position: absolute; inset: 24px 0 48px 72px; padding: 18px; border-radius: 34px; background: rgba(255,255,255,.13); border: 1px solid rgba(255,255,255,.22); box-shadow: 0 36px 100px rgba(0,0,0,.30); transform: rotateY(-5deg) rotateX(2deg); overflow: hidden; }
.hero-photo-secondary { position: absolute; width: 250px; height: 188px; left: 0; bottom: 68px; padding: 12px; border-radius: 26px; background: rgba(250,247,239,.28); border: 1px solid rgba(255,255,255,.34); box-shadow: 0 24px 70px rgba(0,0,0,.28); backdrop-filter: blur(14px); animation: softFloat 7s ease-in-out infinite; }
.hero-stat-card, .hero-ops-card { position: absolute; z-index: 4; border-radius: 20px; color: var(--charcoal); background: rgba(250,247,239,.92); border: 1px solid rgba(255,255,255,.76); box-shadow: 0 22px 60px rgba(0,0,0,.20); backdrop-filter: blur(16px); }
.hero-stat-card { right: 20px; top: 48px; width: 190px; padding: 18px; }
.hero-stat-card strong { display: block; font-size: 2.1rem; line-height: .9; color: var(--forest); letter-spacing: -.04em; }
.hero-stat-card span, .hero-ops-card span, .hero-ops-card small { color: var(--muted); font-weight: 850; font-size: .78rem; line-height: 1.35; }
.hero-ops-card { left: 94px; bottom: 18px; min-width: 230px; padding: 15px 16px; }
.hero-ops-card div { display: flex; align-items: baseline; gap: 10px; margin-top: 4px; }
.hero-ops-card strong { color: var(--forest); font-size: 1.55rem; letter-spacing: -.04em; }
.home-cert-strip { position: relative; z-index: 2; margin-top: -1px; color: white; background: linear-gradient(90deg, #041f15, #0b4e2b, #041f15); border-top: 1px solid rgba(255,255,255,.1); border-bottom: 1px solid rgba(255,255,255,.1); }
.cert-strip-grid { min-height: 72px; display: grid; grid-template-columns: 1.4fr repeat(4, auto); gap: 18px; align-items: center; }
.cert-strip-grid span { color: rgba(255,255,255,.62); font-weight: 850; }
.cert-strip-grid strong { padding: 9px 12px; border-radius: 999px; color: #fff6cf; background: rgba(214,169,58,.12); border: 1px solid rgba(214,169,58,.24); font-size: .82rem; }
.stats-snapshot { overflow: hidden; background: radial-gradient(circle at 82% 18%, rgba(34,163,90,.25), transparent 24%), radial-gradient(circle at 12% 84%, rgba(214,169,58,.22), transparent 22%), linear-gradient(135deg, #fffdf5, #edf7e8 54%, #dceedd); }
.stats-snapshot:before { content: ""; position: absolute; inset: 0; opacity: .18; background-image: repeating-radial-gradient(ellipse at 20% 30%, transparent 0 16px, rgba(6,59,36,.18) 17px 18px), repeating-linear-gradient(135deg, transparent 0 30px, rgba(6,59,36,.08) 31px 32px); pointer-events: none; }
.stats-grid { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.glass-stat { min-height: 166px; display: flex; flex-direction: column; justify-content: space-between; background: rgba(255,255,255,.62); border: 1px solid rgba(255,255,255,.76); backdrop-filter: blur(16px); }
.glass-stat i { width: 42px; height: 28px; border-radius: 50%; border: 2px solid rgba(15,122,58,.26); border-left-color: transparent; transform: rotate(-18deg); }
.credibility-section { color: white; overflow: hidden; background: radial-gradient(circle at 80% 18%, rgba(214,169,58,.22), transparent 24%), linear-gradient(135deg, #031b12, #082f20 48%, #0a4328); }
.credibility-section:before { content: ""; position: absolute; inset: 0; opacity: .12; background-image: linear-gradient(110deg, transparent 0 48%, rgba(214,169,58,.45) 49% 49.5%, transparent 50%), radial-gradient(circle at 80% 30%, rgba(255,255,255,.35) 1px, transparent 2px); background-size: 120px 120px, 38px 38px; }
.credibility-grid { position: relative; z-index: 1; display: grid; grid-template-columns: .9fr 1.1fr; gap: 44px; align-items: center; }
.credibility-copy h2 { font-size: clamp(2.2rem, 4.5vw, 4.8rem); line-height: .96; letter-spacing: -.04em; margin: 18px 0; }
.credibility-copy p { color: rgba(255,255,255,.76); line-height: 1.8; }
.gold-rule { width: 120px; height: 3px; margin: 26px 0; background: linear-gradient(90deg, var(--gold), transparent); border-radius: 999px; }
.credibility-stack { display: grid; gap: 12px; }
.cred-card { padding: 18px 20px; border-radius: 22px; background: rgba(255,255,255,.09); border: 1px solid rgba(255,255,255,.14); backdrop-filter: blur(16px); box-shadow: 0 20px 50px rgba(0,0,0,.12); }
.cred-card span { color: var(--gold-2); font-weight: 950; font-size: .78rem; }
.cred-card h3 { margin: 5px 0 4px; font-size: 1.04rem; font-weight: 950; }
.cred-card p { color: rgba(255,255,255,.68); line-height: 1.55; margin: 0; }
.operations-section { background: linear-gradient(180deg, #faf7ef, #f2efe3); }
.ops-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.ops-card { padding: 22px; border-radius: 26px; background: linear-gradient(145deg, rgba(255,255,255,.92), rgba(246,241,225,.78)); border: 1px solid rgba(6,59,36,.10); box-shadow: var(--shadow-soft); transition: transform .22s ease, box-shadow .22s ease; }
.ops-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.ops-card h3 { margin: 18px 0 4px; font-size: 1rem; font-weight: 950; }
.ops-card strong { display: block; color: var(--forest); font-size: 1.55rem; letter-spacing: -.035em; }
.ops-card p { color: var(--muted); line-height: 1.55; margin-top: 8px; }
.mini-chart { height: 44px; border-radius: 16px; background: rgba(15,122,58,.10); padding: 16px 12px; }
.mini-chart span { display: block; width: var(--w); height: 12px; border-radius: 999px; background: linear-gradient(90deg, var(--green), var(--gold)); }
.mini-gauge { width: 58px; height: 58px; border-radius: 50%; background: conic-gradient(var(--green) var(--p), rgba(15,122,58,.12) 0); position: relative; }
.mini-gauge:after { content: ""; position: absolute; inset: 10px; border-radius: 50%; background: #f9f5e9; }
.process-lines { display: grid; gap: 7px; width: 100px; }
.process-lines span { height: 8px; border-radius: 999px; background: linear-gradient(90deg, var(--forest), var(--leaf)); }
.process-lines span:nth-child(2) { width: 76%; } .process-lines span:nth-child(3) { width: 54%; }
.centre-map { display: grid; grid-template-columns: repeat(3, 18px); gap: 8px; }
.centre-map span { width: 18px; height: 18px; border-radius: 7px; background: rgba(15,122,58,.22); border: 1px solid rgba(15,122,58,.35); }
.field-pattern, .contour-mark { width: 112px; height: 58px; border-radius: 18px; background: repeating-linear-gradient(135deg, rgba(15,122,58,.35) 0 2px, transparent 2px 13px), rgba(15,122,58,.08); }
.contour-mark { background: repeating-radial-gradient(ellipse at 32% 42%, transparent 0 8px, rgba(15,122,58,.34) 9px 10px), rgba(214,169,58,.10); }
.featured-marketplace { overflow: hidden; background: radial-gradient(circle at 84% 18%, rgba(34,163,90,.20), transparent 24%), radial-gradient(circle at 15% 90%, rgba(214,169,58,.20), transparent 22%), linear-gradient(180deg, #fffbf1, #f1eadb); }
.featured-marketplace:before { content: ""; position: absolute; inset: 0; opacity: .12; background-image: repeating-linear-gradient(135deg, transparent 0 28px, rgba(6,59,36,.12) 29px 30px); pointer-events: none; }
.home-product-grid { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.home-product-card { padding: 18px; border-radius: 26px; background: rgba(255,255,255,.78); border: 1px solid rgba(255,255,255,.82); box-shadow: var(--shadow-soft); transition: transform .24s ease, box-shadow .24s ease; }
.home-product-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.home-product-card h3 { font-size: 1.2rem; font-weight: 950; margin: 10px 0 6px; }
.home-product-card p { color: var(--muted); line-height: 1.55; min-height: 74px; }
.product-photo { height: 170px; border-radius: 22px; margin-bottom: 14px; position: relative; overflow: hidden; background: radial-gradient(circle at 68% 22%, rgba(244,197,66,.72), transparent 14%), linear-gradient(145deg, #0f2f20, #24a15a); }
.product-photo:before { content: ""; position: absolute; width: 118px; height: 118px; border-radius: 28px; left: 50%; top: 50%; transform: translate(-50%, -44%) rotate(-8deg); background: linear-gradient(160deg, #fbf3dd, #e5d6a5); box-shadow: 0 18px 35px rgba(0,0,0,.18); }
.product-photo:after { content: attr(data-pack); position: absolute; left: 18px; bottom: 16px; padding: 8px 11px; border-radius: 12px; background: rgba(6,59,36,.78); color: white; font-weight: 950; font-size: .78rem; }
.specialty-showcase { color: white; overflow: hidden; background: radial-gradient(circle at 80% 12%, rgba(214,169,58,.30), transparent 24%), linear-gradient(135deg, #091812, #103522 50%, #4d3b16); }
.specialty-showcase .section-heading p { color: rgba(255,255,255,.76); }
.specialty-grid { display: grid; grid-template-columns: 1.15fr repeat(2, 1fr); gap: 18px; }
.specialty-card { min-height: 250px; display: grid; grid-template-columns: 120px 1fr; gap: 16px; align-items: stretch; padding: 16px; border-radius: 28px; background: rgba(250,247,239,.94); color: var(--charcoal); border: 1px solid rgba(255,255,255,.7); box-shadow: 0 24px 70px rgba(0,0,0,.20); }
.specialty-card.featured { grid-row: span 2; grid-template-columns: 1fr; }
.specialty-card h3 { margin: 10px 0 8px; font-weight: 950; font-size: 1.25rem; }
.specialty-card p { color: var(--muted); line-height: 1.6; }
.specialty-image { min-height: 118px; border-radius: 22px; background: radial-gradient(circle at 70% 20%, rgba(244,197,66,.65), transparent 16%), linear-gradient(145deg, #18442b, #b39333); position: relative; overflow: hidden; }
.specialty-card.featured .specialty-image { min-height: 260px; }
.specialty-image:before { content: ""; position: absolute; inset: 20px; border-radius: 50%; border: 20px solid rgba(250,247,239,.78); }
.specialty-image:after { content: attr(data-label); position: absolute; left: 14px; bottom: 14px; padding: 8px 10px; border-radius: 12px; background: rgba(6,59,36,.78); color: white; font-size: .74rem; font-weight: 950; }
.specialty-actions { justify-content: center; margin-top: 28px; }
.buyer-flow-section { background: linear-gradient(180deg, #faf7ef, #f5f2e8); }
.sustainability-preview { background: linear-gradient(135deg, #eef7e9, #fffaf0); }
.sustainability-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: 34px; align-items: center; }
.sustainability-grid h2 { font-size: clamp(2rem, 4vw, 4rem); line-height: 1; letter-spacing: -.04em; margin: 14px 0; }
.sustainability-grid p { color: var(--muted); line-height: 1.8; }
.final-home-cta { color: white; background: radial-gradient(circle at 50% 0, rgba(214,169,58,.26), transparent 24%), linear-gradient(135deg, #031b12, var(--forest)); }
.final-home-cta .section-heading p { color: rgba(255,255,255,.76); }
.premium-image-card { isolation: isolate; }
.photo-placeholder.has-image { background-image: linear-gradient(160deg, rgba(6,59,36,.08), rgba(6,59,36,.34)), var(--image, none), linear-gradient(145deg, #2a8b4c, #0b4229); }
.image-factory { background-image: linear-gradient(160deg, rgba(6,59,36,.10), rgba(6,59,36,.42)), var(--image, none), linear-gradient(150deg, #244732 0%, #6e8d53 38%, #d2b76b 39%, #314b36 58%, #0b2d1f 100%); }
.image-tasting { background-image: linear-gradient(160deg, rgba(6,59,36,.12), rgba(6,59,36,.30)), var(--image, none), radial-gradient(circle at 32% 42%, rgba(250,247,239,.86) 0 14%, transparent 15%), radial-gradient(circle at 70% 30%, rgba(214,169,58,.72) 0 9%, transparent 10%), linear-gradient(145deg, #143923, #805f22); }
.image-farmers { background-image: linear-gradient(160deg, rgba(6,59,36,.10), rgba(6,59,36,.34)), var(--image, none), linear-gradient(150deg, #9ecb83 0 28%, #5f9f52 29% 43%, #2f6b3b 44% 65%, #123a27 66%); }
.photo-placeholder { transition: transform .45s ease, filter .45s ease; }
.premium-image-card:hover .photo-placeholder { transform: scale(1.025); filter: saturate(1.05); }
.visual-bp1, .visual-pf1, .visual-dust, .visual-ctc { --visual-bg: radial-gradient(circle at 74% 18%, rgba(214,169,58,.42), transparent 16%), repeating-linear-gradient(18deg, rgba(250,247,239,.08) 0 2px, transparent 2px 14px), linear-gradient(145deg, #21180f, #4d331b 42%, #10251a); }
.visual-green, .visual-green-tea { --visual-bg: radial-gradient(circle at 74% 18%, rgba(167,243,208,.58), transparent 16%), repeating-linear-gradient(135deg, rgba(250,247,239,.12) 0 2px, transparent 2px 18px), linear-gradient(145deg, #1c5f38, #87b95b); }
.visual-purple, .visual-purple-tea { --visual-bg: radial-gradient(circle at 74% 18%, rgba(214,169,58,.42), transparent 16%), linear-gradient(145deg, #182e22, #5e3f78 55%, #194d34); }
.visual-white, .visual-white-silver-tea, .visual-white-silver { --visual-bg: radial-gradient(circle at 72% 18%, rgba(214,169,58,.38), transparent 16%), linear-gradient(145deg, #f7f3e8, #cbd6c9 45%, #516d57); }
.visual-golden, .visual-golden-tips, .visual-golden-tips-tea { --visual-bg: radial-gradient(circle at 70% 18%, rgba(255,246,190,.66), transparent 18%), linear-gradient(145deg, #3a2a12, #c79b2d 54%, #123923); }
.visual-oolong, .visual-oolong-tea { --visual-bg: radial-gradient(circle at 74% 18%, rgba(244,197,66,.46), transparent 16%), linear-gradient(145deg, #18261c, #9c6c2b 52%, #2f1f14); }
.product-photo, .product-card .product-art.product-photo { height: 178px; border-radius: 22px; margin: 0 0 14px; position: relative; overflow: hidden; background-color: #173a27; background-image: linear-gradient(180deg, rgba(6,59,36,.04), rgba(6,59,36,.46)), var(--image, none), var(--visual-bg, linear-gradient(145deg, #123c27, #1fa157)); background-size: cover; background-position: center; box-shadow: inset 0 1px 0 rgba(255,255,255,.24); transition: transform .35s ease, filter .35s ease; }
.home-product-card:hover .product-photo, .market-product-card:hover .product-photo { transform: scale(1.025); filter: saturate(1.06); }
.product-card .product-art.product-photo:before, .product-photo:before { content: ""; position: absolute; inset: 0; border: 0; border-radius: inherit; background: linear-gradient(135deg, transparent 0 55%, rgba(250,247,239,.10) 56% 57%, transparent 58%), repeating-linear-gradient(160deg, rgba(255,255,255,.08) 0 1px, transparent 1px 18px); opacity: .72; transform: none; box-shadow: none; }
.product-card .product-art.product-photo:after, .product-photo:after { content: attr(data-pack); position: absolute; left: 14px; bottom: 14px; max-width: calc(100% - 28px); padding: 8px 11px; border-radius: 12px; background: rgba(6,59,36,.78); color: white; font-weight: 950; font-size: .76rem; line-height: 1.15; backdrop-filter: blur(10px); }
.home-product-card { display: flex; flex-direction: column; }
.home-product-card .card-actions { margin-top: auto; }
.market-product-card { display: flex; flex-direction: column; }
.market-product-card .glass-panel { background: rgba(250,247,239,.78); border-color: rgba(6,59,36,.08); }
.market-product-card .card-actions { margin-top: auto; }
.specialty-image { background-image: linear-gradient(180deg, rgba(6,59,36,.02), rgba(6,59,36,.34)), var(--image, none), var(--visual-bg, linear-gradient(145deg, #18442b, #b39333)); background-size: cover; background-position: center; transition: transform .35s ease, filter .35s ease; }
.specialty-card:hover .specialty-image { transform: scale(1.02); filter: saturate(1.05); }
.specialty-image:before { inset: 0; border: 0; border-radius: inherit; background: repeating-linear-gradient(150deg, rgba(255,255,255,.10) 0 1px, transparent 1px 20px); opacity: .55; }

.marketplace-wide {
  width: 100%;
  max-width: 1760px;
  margin: 0 auto;
  padding-left: clamp(16px, 3vw, 48px);
  padding-right: clamp(16px, 3vw, 48px);
}
.marketplace-compact-hero {
  padding: 24px 0 16px;
  color: white;
  background: radial-gradient(circle at 80% 20%, rgba(34,163,90,.16), transparent 30%), linear-gradient(135deg, #031c12, var(--forest));
}
.marketplace-slider {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-items: stretch;
}
.marketplace-slide {
  min-height: 190px;
  max-height: 240px;
  padding: 20px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 12px 30px rgba(0,0,0,0.15);
  background-size: cover;
  background-position: center;
}
.marketplace-slide h1, .marketplace-slide h2 {
  margin: 4px 0;
  font-size: clamp(1.2rem, 1.8vw, 1.6rem);
  line-height: 1.1;
  font-weight: 800;
  color: white;
}
.marketplace-slide p {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.4;
  margin-top: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.marketplace-slide .btn-primary, .marketplace-slide .btn-secondary {
  min-height: 34px;
  padding: 0 14px;
  font-size: 0.78rem;
  margin-top: 10px;
  align-self: flex-start;
}
.marketplace-slide.ctc-slide { background-image: linear-gradient(135deg, rgba(4,25,16,.82), rgba(28,77,42,.54)), var(--image, none), radial-gradient(circle at 72% 25%, rgba(214,169,58,.42), transparent 18%), linear-gradient(145deg, #1c160e, #0f4d2c); }
.marketplace-slide.specialty-slide { background-image: linear-gradient(135deg, rgba(4,25,16,.72), rgba(73,56,18,.58)), radial-gradient(circle at 72% 24%, rgba(244,197,66,.36), transparent 20%), linear-gradient(145deg, #0d2b1c, #704d1b); }
.marketplace-slide.export-slide { background-image: linear-gradient(135deg, rgba(4,25,16,.74), rgba(6,59,36,.72)), repeating-linear-gradient(145deg, rgba(255,255,255,.08) 0 1px, transparent 1px 18px), linear-gradient(145deg, #063b24, #0f7a3a); }
.marketplace-tools {
  position: sticky;
  top: 82px;
  z-index: 20;
  padding: 12px 0;
  background: rgba(250,247,239,.86);
  border-bottom: 1px solid rgba(6,59,36,.08);
  backdrop-filter: blur(14px);
}
.compact-filter {
  border-radius: 20px;
  padding: 16px 24px;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(6,59,36,0.06);
  box-shadow: 0 10px 30px rgba(6,59,36,0.05);
}
.marketplace-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
  border-top: 1px solid rgba(6,59,36,0.06);
  padding-top: 12px;
  color: var(--forest);
}
.basket-summary-pill, .basket-count { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; font-weight: 950; }
.basket-summary-pill { min-height: 44px; padding: 0 16px; color: white; background: linear-gradient(135deg, var(--green), var(--forest)); box-shadow: var(--shadow-soft); }
.basket-summary-pill b, .basket-count { min-width: 24px; height: 24px; margin-left: 7px; padding: 0 7px; color: #1f1a0d; background: var(--gold-2); font-size: .75rem; }
.marketplace-product-section { overflow: hidden; background: radial-gradient(circle at 86% 8%, rgba(34,163,90,.14), transparent 22%), radial-gradient(circle at 10% 95%, rgba(214,169,58,.16), transparent 24%), linear-gradient(180deg, #fffaf0, #f1eadb); }
.marketplace-heading h1, .marketplace-heading h2, .quote-basket-section h1, .quote-request-section h1, .marketplace-account-section h1 { font-size: clamp(2rem, 3.6vw, 4rem); line-height: 1; letter-spacing: -.04em; font-weight: 950; margin: 10px 0; }
.marketplace-grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 20px;
}
.catalog-card {
  display: flex;
  flex-direction: column;
  background: white;
  border: 1px solid rgba(6, 59, 36, 0.08);
  border-radius: 20px;
  padding: 18px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.03);
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.catalog-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 15px 35px rgba(6, 59, 36, 0.08);
}
.catalog-card h3 {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 10px 0 4px;
  color: var(--forest);
}
.catalog-card h3 a {
  color: var(--forest);
}
.catalog-card h3 a:hover {
  color: var(--green);
}
.catalog-card p {
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 12px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  height: 4.5em;
}
.packaging-chips { display: flex; flex-wrap: wrap; gap: 7px; margin: 12px 0; }
.packaging-chips span { padding: 6px 9px; border-radius: 999px; color: var(--forest); background: rgba(15,122,58,.09); font-size: .72rem; font-weight: 900; }
.quote-card-form, .quote-detail-form, .basket-update-form, .quote-submit-form, .account-panel { display: grid; gap: 12px; }
.quote-card-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: auto;
}
.quote-card-form label, .quote-detail-form label, .basket-update-form label, .quote-submit-form label, .account-panel label { display: grid; gap: 6px; color: var(--muted); font-size: .74rem; font-weight: 950; text-transform: uppercase; letter-spacing: .06em; }
.quote-card-form input, .quote-card-form select, .quote-detail-form input, .quote-detail-form select, .basket-update-form input, .quote-submit-form input, .quote-submit-form select, .quote-submit-form textarea, .account-panel input { width: 100%; min-height: 38px; border: 1px solid rgba(6,59,36,.14); border-radius: 12px; padding: 0 12px; color: var(--charcoal); background: rgba(255,255,255,.82); outline: 0; text-transform: none; letter-spacing: 0; font-weight: 800; }
.quote-card-form .card-actions {
  grid-column: span 2;
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 8px;
  margin-top: 10px;
}
.quote-card-form .card-actions .btn-primary {
  width: 100%;
  min-height: 38px;
  border-radius: 99px;
  font-size: 0.82rem;
  font-weight: 700;
  box-shadow: 0 8px 20px rgba(6,59,36,0.15);
}
.quote-card-form .card-actions .btn-secondary {
  width: 100%;
  min-height: 38px;
  border-radius: 99px;
  font-size: 0.82rem;
  color: var(--forest);
  border: 1px solid rgba(6,59,36,0.16);
  background: white;
  box-shadow: none;
}
.quote-submit-form textarea { padding: 12px; resize: vertical; }
.product-detail-section { color: var(--charcoal); background: radial-gradient(circle at 85% 12%, rgba(214,169,58,.18), transparent 22%), linear-gradient(180deg, #faf7ef, #efe6d2); }
.product-detail-layout { display: grid; grid-template-columns: minmax(0, 1fr) 420px; gap: 36px; align-items: start; }
.product-gallery { display: grid; gap: 14px; }
.gallery-main { min-height: 480px; height: 480px; border-radius: 24px; overflow: hidden; background: #173a27; box-shadow: var(--shadow); }
.gallery-main img, .gallery-thumbs img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gallery-main .product-photo { height: 480px; border-radius: 24px; margin: 0; }
.gallery-thumbs { display: flex; gap: 12px; margin-top: 12px; overflow-x: auto; padding-bottom: 6px; }
.gallery-thumbs figure { flex: 0 0 100px; height: 75px; min-height: 75px; margin: 0; overflow: hidden; border-radius: 12px; background: rgba(255,255,255,.72); border: 2px solid transparent; cursor: pointer; transition: all 0.2s; }
.gallery-thumbs figure.active { border-color: var(--gold); transform: scale(0.96); }
.gallery-thumbs figcaption { display: none; }
.gallery-placeholder { display: grid; place-items: end start; padding: 14px; color: white; background-image: var(--visual-bg, linear-gradient(145deg, #123c27, #1fa157)); }
.product-purchase-panel { position: sticky; top: 112px; }
.product-purchase-panel h1 { font-size: clamp(2rem, 3vw, 3.5rem); line-height: 1; letter-spacing: -.04em; margin: 16px 0; font-weight: 950; }
.detail-meta { margin: 18px 0; }
.detail-tabs-nav { display: flex; gap: 8px; border-bottom: 1px solid rgba(6,59,36,0.08); margin-bottom: 20px; overflow-x: auto; padding-bottom: 4px; }
.detail-tab-btn { padding: 10px 18px; background: transparent; border: 0; font-weight: 700; color: var(--muted); cursor: pointer; font-size: 0.9rem; border-bottom: 2px solid transparent; white-space: nowrap; transition: all 0.2s; }
.detail-tab-btn.active { color: var(--forest); border-bottom-color: var(--gold); }
.detail-tab-content { display: none; animation: fadeIn 0.3s ease-out; }
.detail-tab-content.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }
.detail-tabs { display: grid; gap: 20px; }
.related-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.quote-basket-section, .quote-request-section, .marketplace-account-section { background: radial-gradient(circle at 88% 10%, rgba(34,163,90,.16), transparent 22%), linear-gradient(180deg, #faf7ef, #efe6d2); }
.quote-basket-layout { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 30px; align-items: start; }
.basket-list { display: grid; gap: 16px; }
.basket-item { display: grid; grid-template-columns: 140px 1fr; gap: 20px; padding: 20px; background: white; border-radius: 20px; border: 1px solid rgba(6,59,36,0.06); box-shadow: 0 4px 15px rgba(0,0,0,0.02); }
.basket-image.product-photo { height: 130px; margin: 0; border-radius: 16px; }
.basket-item-main h3 { margin: 4px 0 6px; font-size: 1.3rem; font-weight: 800; color: var(--forest); }
.basket-update-form { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 12px; margin-top: 12px; }
.basket-update-form label { font-size: 0.7rem; font-weight: 700; color: var(--muted); text-transform: uppercase; display: flex; flex-direction: column; gap: 4px; }
.basket-update-form input, .basket-update-form select { height: 38px; border-radius: 10px; border: 1px solid rgba(6,59,36,0.12); padding: 0 10px; font-size: 0.85rem; background: var(--cream); }
.basket-update-form .btn-secondary { height: 38px; min-height: 38px; padding: 0 16px; border-radius: 10px; background: var(--forest); color: white; font-size: 0.82rem; cursor: pointer; border: 0; }
.basket-update-form .remove-link { height: 38px; padding: 0 12px; display: flex; align-items: center; color: #b91c1c; font-weight: 700; font-size: 0.82rem; background: transparent; border: 0; cursor: pointer; }
.basket-update-form .remove-link:hover { text-decoration: underline; }
.basket-summary-panel { display: grid; gap: 14px; position: sticky; top: 112px; background: linear-gradient(135deg, rgba(6, 59, 36, 0.03), rgba(214, 169, 58, 0.05)); border: 1px solid rgba(6,59,36,0.08); border-radius: 24px; padding: 24px; box-shadow: 0 10px 35px rgba(6,59,36,0.04); }
.basket-summary-panel h2 { font-size: 1.45rem; font-weight: 800; color: var(--forest); margin: 8px 0 16px; }
.summary-lines { display: grid; gap: 10px; margin: 12px 0; }
.summary-lines p { display: flex; justify-content: space-between; gap: 14px; margin: 0; padding: 12px 0; border-bottom: 1px solid rgba(6,59,36,.10); color: var(--muted); }
.summary-lines strong { color: var(--charcoal); }
.empty-basket { text-align: center; max-width: 720px; margin: 0 auto; }
.quote-request-layout { display: grid; grid-template-columns: .8fr 1fr; gap: 24px; align-items: start; }
.quote-submit-form { padding: 24px; }
.account-grid { display: grid; grid-template-columns: .9fr 1fr 1fr; gap: 20px; align-items: start; }
.account-panel h2 { font-size: 1.55rem; font-weight: 950; margin: 0 0 8px; }
.form-errors { padding: 12px; border-radius: 14px; color: #7a1f12; background: #fff1eb; font-weight: 850; }
.leader-photo, .avatar-mark { width: 58px; height: 58px; border-radius: 20px; display: grid; place-items: center; color: var(--forest); background: linear-gradient(145deg, #fff7dc, #dff8e9); border: 1px solid rgba(214,169,58,.28); font-weight: 950; box-shadow: var(--shadow-soft); }

/* Unified authenticated workspace */
.workspace-body { min-height: 100vh; display: grid; grid-template-columns: 292px minmax(0, 1fr); color: var(--charcoal); background: radial-gradient(circle at 82% 0, rgba(34,163,90,.12), transparent 24%), linear-gradient(180deg, #f7f3e8, #edf5ea); }
.workspace-sidebar { position: sticky; top: 0; height: 100vh; overflow-y: auto; padding: 22px 16px; color: white; background: linear-gradient(180deg, #031b12, #082a1b 52%, #051a12); border-right: 1px solid rgba(255,255,255,.08); z-index: 90; }
.workspace-brand { display: flex; align-items: center; gap: 12px; padding: 8px 10px 22px; border-bottom: 1px solid rgba(255,255,255,.10); margin-bottom: 14px; }
.workspace-brand strong { display: block; color: white; font-size: .98rem; font-weight: 950; line-height: 1.1; }
.workspace-brand small { display: block; color: rgba(255,255,255,.58); margin-top: 4px; font-size: .72rem; font-weight: 800; }
.workspace-nav { display: grid; gap: 18px; }
.workspace-nav-group > span { display: block; padding: 0 10px 8px; color: rgba(255,255,255,.48); font-size: .68rem; font-weight: 950; letter-spacing: .13em; text-transform: uppercase; }
.workspace-nav a, .workspace-nav button { width: 100%; min-height: 42px; display: flex; align-items: center; padding: 10px 12px; border-radius: 14px; border: 0; color: rgba(255,255,255,.72); background: transparent; font-weight: 850; text-align: left; transition: background .18s ease, color .18s ease, transform .18s ease; cursor: pointer; }
.workspace-nav a:hover, .workspace-nav a.active, .workspace-nav button:hover { color: white; background: rgba(214,169,58,.14); transform: translateX(2px); }
.workspace-main { min-width: 0; }
.workspace-topbar { position: sticky; top: 0; z-index: 70; min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 14px clamp(18px, 3vw, 36px); background: rgba(250,247,239,.88); border-bottom: 1px solid rgba(6,59,36,.10); backdrop-filter: blur(18px); }
.workspace-title span { display: block; color: var(--muted); font-size: .72rem; font-weight: 950; letter-spacing: .12em; text-transform: uppercase; }
.workspace-title h1 { margin: 4px 0 0; font-size: clamp(1.35rem, 2.5vw, 2.35rem); line-height: 1; font-weight: 950; letter-spacing: -.035em; color: var(--forest); }
.workspace-user { display: flex; align-items: center; gap: 10px; }
.workspace-notification, .workspace-avatar { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 15px; color: var(--forest); background: white; border: 1px solid rgba(6,59,36,.10); box-shadow: var(--shadow-soft); font-weight: 950; }
.workspace-notification { color: #1f1a0d; background: linear-gradient(135deg, var(--gold-2), var(--gold)); }
.workspace-user-meta strong { display: block; font-size: .86rem; font-weight: 950; color: var(--forest); }
.workspace-user-meta small { display: block; color: var(--muted); font-size: .72rem; font-weight: 800; }
.workspace-menu-btn { display: none; width: 44px; height: 44px; border-radius: 14px; border: 1px solid rgba(6,59,36,.12); background: white; padding: 10px; }
.workspace-menu-btn span { display: block; height: 2px; margin: 5px 0; border-radius: 999px; background: var(--forest); }
.workspace-content { padding: clamp(18px, 3vw, 36px); }
.workspace-dashboard { width: min(1760px, 100%); margin: 0 auto; }
.workspace-hero-card, .workspace-page-head, .workspace-panel, .workspace-kpi-card, .workspace-action-card, .workspace-quote-card { border: 1px solid rgba(255,255,255,.78); background: rgba(255,255,255,.78); box-shadow: var(--shadow-soft); backdrop-filter: blur(14px); }
.workspace-hero-card { display: flex; align-items: end; justify-content: space-between; gap: 24px; padding: clamp(22px, 3vw, 34px); border-radius: 30px; overflow: hidden; background: radial-gradient(circle at 85% 0, rgba(214,169,58,.22), transparent 24%), linear-gradient(135deg, rgba(255,255,255,.88), rgba(239,247,234,.78)); }
.workspace-hero-card h2, .workspace-page-head h2 { margin: 12px 0; color: var(--forest); font-size: clamp(2rem, 4vw, 4rem); line-height: .98; letter-spacing: -.045em; font-weight: 950; }
.workspace-hero-card p, .workspace-page-head p, .workspace-muted { color: var(--muted); line-height: 1.7; }
.workspace-hero-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.workspace-badges { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.workspace-badges span { padding: 7px 10px; border-radius: 999px; color: var(--forest); background: rgba(15,122,58,.10); font-size: .72rem; font-weight: 950; }
.workspace-kpi-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; margin: 18px 0; }
.workspace-kpi-card { min-height: 150px; padding: 20px; border-radius: 24px; }
.workspace-kpi-card p { margin: 0; color: var(--muted); font-weight: 850; }
.workspace-kpi-card strong { display: block; margin: 14px 0 4px; color: var(--forest); font-size: clamp(2rem, 4vw, 3rem); line-height: .9; letter-spacing: -.045em; font-weight: 950; }
.workspace-kpi-card span { color: var(--green); font-size: .78rem; font-weight: 950; }
.workspace-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px; }
.workspace-panel { border-radius: 26px; padding: 22px; overflow: hidden; }
.workspace-panel-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.workspace-panel-head h2 { margin: 8px 0 0; color: var(--forest); font-size: clamp(1.3rem, 2vw, 2rem); line-height: 1; font-weight: 950; letter-spacing: -.035em; }
.workspace-panel-head a { color: var(--green); font-weight: 950; }
.workspace-action-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.workspace-action-card { padding: 18px; border-radius: 22px; }
.workspace-action-card h3 { color: var(--forest); font-size: 1.08rem; font-weight: 950; margin: 0 0 8px; }
.workspace-action-card p { min-height: 52px; color: var(--muted); line-height: 1.55; }
.workspace-mini-list { display: grid; gap: 10px; }
.workspace-mini-list p { display: flex; justify-content: space-between; gap: 14px; margin: 0; padding: 12px 0; border-bottom: 1px solid rgba(6,59,36,.10); color: var(--muted); }
.workspace-mini-list strong { color: var(--charcoal); }
.workspace-mini-list span { text-align: right; font-weight: 900; color: var(--forest); }
.workspace-activity-list { display: grid; gap: 10px; }
.workspace-activity-list a { display: grid; grid-template-columns: 120px 1fr auto; gap: 12px; align-items: center; padding: 13px; border-radius: 16px; background: rgba(15,122,58,.06); border: 1px solid rgba(6,59,36,.08); }
.workspace-activity-list span { color: var(--green); font-size: .78rem; font-weight: 950; }
.workspace-activity-list strong { color: var(--forest); }
.workspace-activity-list em { color: var(--muted); font-style: normal; font-size: .82rem; font-weight: 850; }
.workspace-report-card { display: grid; grid-template-columns: 130px 1fr; gap: 18px; align-items: center; }
.workspace-donut { width: 126px; height: 126px; border-radius: 50%; background: conic-gradient(var(--green) 0 42%, var(--gold) 42% 68%, var(--mint) 68% 84%, rgba(6,59,36,.12) 84%); position: relative; }
.workspace-donut:after { content: ""; position: absolute; inset: 24px; border-radius: 50%; background: #f8f5eb; }
.workspace-bar-grid { display: grid; gap: 14px; }
.workspace-bar-grid div { display: grid; grid-template-columns: 140px 1fr 40px; align-items: center; gap: 12px; }
.workspace-bar-grid span { color: var(--muted); font-weight: 850; }
.workspace-bar-grid i { display: block; height: 12px; border-radius: 999px; background: rgba(15,122,58,.10); overflow: hidden; }
.workspace-bar-grid i:after { content: ""; display: block; width: var(--w); height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--green), var(--gold)); }
.workspace-bar-grid strong { color: var(--forest); }
.workspace-page-head { display: flex; align-items: end; justify-content: space-between; gap: 22px; padding: 24px; border-radius: 28px; margin-bottom: 18px; }
.workspace-filter-panel { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; align-items: end; padding: 16px; margin-bottom: 18px; border-radius: 24px; background: rgba(255,255,255,.78); border: 1px solid rgba(255,255,255,.78); box-shadow: var(--shadow-soft); }
.workspace-filter-panel label, .workspace-management-form label { display: grid; gap: 7px; color: var(--muted); font-size: .75rem; font-weight: 950; text-transform: uppercase; letter-spacing: .06em; }
.workspace-filter-panel select, .workspace-management-form select, .workspace-management-form textarea { width: 100%; min-height: 42px; padding: 0 12px; border-radius: 14px; border: 1px solid rgba(6,59,36,.14); color: var(--charcoal); background: white; text-transform: none; letter-spacing: 0; font-weight: 800; }
.workspace-management-form textarea { min-height: 120px; padding: 12px; resize: vertical; }
.workspace-table-wrap { width: 100%; overflow-x: auto; }
.workspace-table th, .workspace-table td { color: var(--charcoal); border-bottom: 1px solid rgba(6,59,36,.10); white-space: nowrap; }
.workspace-table th { color: var(--muted); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; }
.workspace-quote-cards { display: none; }
.workspace-quote-card { padding: 18px; border-radius: 22px; }
.workspace-quote-card div { display: flex; justify-content: space-between; gap: 12px; }
.workspace-quote-card span { color: var(--green); font-weight: 950; }
.workspace-quote-card strong { color: var(--forest); }
.workspace-quote-card h3 { margin: 12px 0 6px; color: var(--forest); font-weight: 950; }
.workspace-quote-card p { color: var(--muted); margin: 0 0 10px; }
.workspace-status-track { display: grid; gap: 10px; }
.workspace-status-track div { display: grid; grid-template-columns: 36px 1fr; gap: 10px; align-items: center; padding: 11px; border-radius: 16px; background: rgba(15,122,58,.06); color: var(--muted); font-weight: 850; }
.workspace-status-track i { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; background: rgba(15,122,58,.12); color: var(--forest); font-style: normal; font-weight: 950; }
.workspace-status-track div.active { background: rgba(214,169,58,.16); color: var(--forest); }
.workspace-status-track div.active i { background: linear-gradient(135deg, var(--gold-2), var(--gold)); color: #1f1a0d; }
.workspace-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.workspace-full { grid-column: 1 / -1; }
.workspace-empty { padding: 18px; border-radius: 18px; color: var(--muted); background: rgba(15,122,58,.06); }
.workspace-backdrop { display: none; }

.marketplace-header .desktop-nav { gap: 16px; }
.marketplace-header .desktop-nav > a { font-size: 0.92rem; font-weight: 700; padding: 8px 16px; border-radius: 99px; }
.marketplace-header .basket-count { background: var(--gold); color: var(--charcoal); font-weight: 900; min-width: 22px; height: 22px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 0.72rem; margin-left: 6px; padding: 0 5px; box-shadow: 0 2px 5px rgba(0,0,0,0.2); }
.nav-menu-trigger .chevron { color: var(--gold) !important; font-weight: 900 !important; font-size: 0.72rem !important; margin-left: 4px; }

@media (min-width: 580px) {
  .marketplace-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 900px) {
  .marketplace-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1280px) {
  .marketplace-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (min-width: 1536px) {
  .marketplace-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}

@media (max-width: 1080px) {
  .desktop-nav { display: none; }
  .mobile-toggle { display: block; }
  .hero-grid, .grid-2, .footer-grid { grid-template-columns: 1fr; }
  .hero-visual { min-height: 440px; }
  .hero-collage .image-panel { width: 100%; }
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .dashboard-shell { grid-template-columns: 1fr; }
  .portal-topbar { align-items: flex-start; flex-direction: column; }
  .portal-user { flex-wrap: wrap; }
  .dash-sidebar { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .span-3, .span-4, .span-5, .span-6, .span-7, .span-8 { grid-column: span 12; }
  .home-hero-grid, .credibility-grid, .sustainability-grid { grid-template-columns: 1fr; }
  .home-hero-visual { min-height: 500px; }
  .hero-photo-main { left: 34px; }
  .stats-grid, .ops-grid, .home-product-grid { grid-template-columns: repeat(2, 1fr); }
  .specialty-grid { grid-template-columns: 1fr 1fr; }
  .specialty-card.featured { grid-row: auto; }
  .marketplace-slider, .product-detail-layout, .quote-basket-layout, .quote-request-layout, .account-grid { grid-template-columns: 1fr; }
  .detail-tabs { grid-template-columns: repeat(2, 1fr); }
  .product-purchase-panel, .basket-summary-panel { position: static; }
}
@media (max-width: 680px) {
  .nav-shell { height: 74px; }
  .brand-lockup { min-width: 0; }
  .brand-lockup strong { font-size: .78rem; }
  .brand-lockup small { display: none; }
  .brand-mark { width: 42px; height: 42px; border-radius: 14px; }
  .hero, .page-hero { padding: 58px 0 84px; }
  .hero h1, .page-hero h1 { font-size: 2.8rem; }
  .hero-visual { min-height: 360px; }
  .image-panel { min-height: 330px; transform: none; }
  .hero-collage { min-height: 480px; }
  .collage-card.tasting { left: 0; bottom: 34px; width: 210px; height: 155px; }
  .collage-card.leaves { right: 0; top: 4px; width: 160px; height: 120px; }
  .floating-card { position: relative; display: inline-block; margin: 8px; left: auto; right: auto; top: auto; bottom: auto; }
  .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .section { padding: 58px 0; }
  .section-heading { display: block; }
  .footer-bottom, .dash-topbar { flex-direction: column; align-items: flex-start; }
  .dash-main { padding: 18px; }
  .dash-sidebar { grid-template-columns: 1fr; }
  .home-hero { padding: 54px 0 46px; }
  .home-hero-copy h1 { font-size: 2.7rem; }
  .home-hero-copy p { font-size: 1rem; }
  .home-hero-visual { min-height: 430px; margin-top: 8px; }
  .hero-photo-main { inset: 0 0 96px 0; transform: none; border-radius: 28px; }
  .hero-photo-secondary { width: 190px; height: 140px; bottom: 42px; left: 0; }
  .hero-stat-card { right: 0; top: 18px; width: 160px; padding: 14px; }
  .hero-stat-card strong { font-size: 1.65rem; }
  .hero-ops-card { left: 20px; bottom: 0; min-width: 0; width: calc(100% - 40px); }
  .cert-strip-grid { grid-template-columns: 1fr 1fr; padding: 16px 0; }
  .cert-strip-grid span { grid-column: 1 / -1; }
  .stats-grid, .ops-grid, .home-product-grid, .specialty-grid { grid-template-columns: 1fr; }
  .glass-stat { min-height: 140px; }
  .specialty-card { grid-template-columns: 1fr; }
  .specialty-card.featured .specialty-image, .specialty-image { min-height: 190px; }
  .home-product-card p { min-height: auto; }
  .product-photo, .product-card .product-art.product-photo { height: 156px; }
  .marketplace-wide { width: min(100% - 24px, 1760px); }
  .marketplace-compact-hero { padding-top: 18px; }
  .marketplace-slide { min-height: 185px; padding: 18px; border-radius: 24px; }
  .marketplace-tools { position: relative; top: auto; }
  .detail-tabs, .gallery-thumbs { grid-template-columns: 1fr; }
  .quote-card-form, .basket-update-form { grid-template-columns: 1fr; }
  .basket-item { grid-template-columns: 1fr; }
  .basket-image.product-photo { height: 170px; }
  .gallery-main, .gallery-main .product-photo { min-height: 340px; height: 340px; }
  .product-purchase-panel h1 { font-size: 2.2rem; }
  .quote-submit-form, .account-panel { padding: 20px; }
}


/* -------------------------------------------
   PHASE 2 MARKETPLACE FRONTEND POLISH
------------------------------------------- */

/* -----------------------------------------
   CAMPAIGN STRIP (Part B)
----------------------------------------- */
.marketplace-campaign-strip {
  background: linear-gradient(90deg, #031c12, #063b24 50%, #031c12);
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: 0;
  overflow: hidden;
}
.campaign-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  min-height: 52px;
}
.campaign-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  border-right: 1px solid rgba(255,255,255,.08);
  transition: background .2s;
}
.campaign-item:last-child { border-right: 0; }
.campaign-item:hover { background: rgba(255,255,255,.04); }
.campaign-label {
  font-size: .68rem;
  font-weight: 900;
  color: var(--gold-2);
  text-transform: uppercase;
  letter-spacing: .10em;
  white-space: nowrap;
}
.campaign-title {
  font-size: .82rem;
  font-weight: 700;
  color: rgba(255,255,255,.86);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
}
.campaign-btn {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 99px;
  font-size: .72rem;
  font-weight: 900;
  white-space: nowrap;
  color: #1f1a0d;
  background: var(--gold-2);
  transition: transform .15s, box-shadow .15s;
}
.campaign-btn:hover { transform: scale(1.04); box-shadow: 0 4px 14px rgba(214,169,58,.4); }

/* -----------------------------------------
   MODERN FILTER TOOLBAR (Part D)
----------------------------------------- */
.filter-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: nowrap;
}
.filter-search-group { flex: 1; min-width: 180px; }
.search-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}
.search-icon {
  position: absolute;
  left: 12px;
  font-size: .88rem;
  pointer-events: none;
  opacity: .5;
  z-index: 1;
}
.search-input-wrapper input[data-search-products] {
  width: 100%;
  min-height: 40px;
  padding: 0 14px 0 36px;
  border: 1px solid rgba(6,59,36,.16);
  border-radius: 99px;
  background: white;
  outline: 0;
  font-size: .88rem;
  color: var(--charcoal);
  transition: border-color .2s, box-shadow .2s;
}
.search-input-wrapper input[data-search-products]:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(15,122,58,.1);
}
.filter-dropdowns-group {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.filter-dropdowns-group .field { margin: 0; }
.filter-dropdowns-group .field label {
  display: flex;
  flex-direction: column;
  gap: 0;
  font-size: .68rem;
  font-weight: 900;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.filter-dropdowns-group select {
  min-height: 36px;
  padding: 0 10px;
  border: 1px solid rgba(6,59,36,.14);
  border-radius: 10px;
  font-size: .82rem;
  background: white;
  color: var(--charcoal);
  cursor: pointer;
  outline: 0;
}
.basket-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--gold-2);
  color: #1f1a0d;
  font-size: .72rem;
  font-weight: 900;
  margin-left: 6px;
  padding: 0 4px;
}
.basket-summary-pill {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 99px;
  background: linear-gradient(135deg, var(--green), var(--forest));
  color: white;
  font-size: .82rem;
  font-weight: 900;
  white-space: nowrap;
  transition: transform .15s;
  flex-shrink: 0;
}
.basket-summary-pill:hover { transform: translateY(-1px); }
.mobile-filter-trigger {
  display: none;
  align-items: center;
  gap: 6px;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(6,59,36,.16);
  border-radius: 99px;
  background: white;
  font-size: .82rem;
  font-weight: 700;
  color: var(--forest);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}
.mobile-filter-trigger.active { background: rgba(15,122,58,.08); }

/* -----------------------------------------
   FILTER CHIPS (Part D)
----------------------------------------- */
.marketplace-filter-chips {
  margin-top: 12px;
  border-top: 1px solid rgba(6,59,36,.06);
  padding-top: 10px;
}
.chips-container {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: none;
}
.chips-container::-webkit-scrollbar { display: none; }
.filter-chip {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 14px;
  border-radius: 99px;
  border: 1.5px solid rgba(6,59,36,.16);
  background: white;
  color: var(--forest);
  font-size: .78rem;
  font-weight: 800;
  white-space: nowrap;
  cursor: pointer;
  transition: all .18s;
}
.filter-chip:hover { border-color: var(--green); background: rgba(15,122,58,.05); }
.filter-chip.active {
  background: linear-gradient(135deg, var(--green), var(--forest));
  color: white;
  border-color: transparent;
  box-shadow: 0 4px 12px rgba(6,59,36,.2);
}

/* Mobile filter drawer */
@media (max-width: 768px) {
  .mobile-filter-trigger { display: inline-flex; }
  .filter-dropdowns-group {
    display: none;
    width: 100%;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(6,59,36,.08);
  }
  .filter-dropdowns-group.open { display: flex; }
  .filter-dropdowns-group .field { flex: 1 1 140px; }
  .filter-dropdowns-group select { width: 100%; }
  .filter-toolbar { flex-wrap: wrap; }
  .basket-summary-pill { min-height: 34px; }
  .campaign-container { grid-template-columns: 1fr; }
  .campaign-item {
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.06);
    padding: 8px 16px;
  }
  .campaign-title { display: none; }
}

/* -----------------------------------------
   PRODUCT CARD REFINEMENTS (Part E)
----------------------------------------- */
.catalog-card { padding: 14px; }
.catalog-card p {
  -webkit-line-clamp: 2;
  height: 2.9em;
}

/* -----------------------------------------
   HIGH-CONTRAST BADGES AND EYEBROWS (Part H)
----------------------------------------- */
/* Light-section eyebrow override (forest green on cream/white bg) */
.section .eyebrow,
.marketplace-product-section .eyebrow,
.quote-basket-section .eyebrow,
.quote-request-section .eyebrow,
.marketplace-account-section .eyebrow,
.high-contrast-eyebrow {
  color: var(--forest) !important;
  background: rgba(15,122,58,.12) !important;
  border-color: rgba(15,122,58,.22) !important;
}
/* Gold eyebrow utility for light cream sections */
.gold-eyebrow {
  color: #7a5012 !important;
  background: rgba(244,197,66,.18) !important;
  border-color: rgba(214,169,58,.32) !important;
}
.product-meta span {
  color: var(--forest);
  background: rgba(15,122,58,.10);
}

/* -----------------------------------------
   EMPTY BASKET VISUAL (Part I)
----------------------------------------- */
.empty-basket-visual {
  margin: 0 auto 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.basket-line-icon {
  width: 80px;
  height: 80px;
  color: var(--forest);
  opacity: .35;
}
.basket-line-icon svg { width: 100%; height: 100%; }

/* -----------------------------------------
   QUOTE PROGRESS TRACKER (Part J)
----------------------------------------- */
.quote-progress-tracker {
  display: flex;
  align-items: center;
  margin-bottom: 32px;
  background: white;
  border: 1px solid rgba(6,59,36,.08);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(6,59,36,.04);
}
.tracker-step {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 20px;
  border-right: 1px solid rgba(6,59,36,.08);
  color: var(--muted);
  transition: background .2s;
}
.tracker-step:last-child { border-right: 0; }
.tracker-step.done { color: var(--green); }
.tracker-step.done .step-num { background: var(--green); color: white; }
.tracker-step.active { background: rgba(15,122,58,.05); color: var(--forest); font-weight: 700; }
.tracker-step.active .step-num { background: var(--forest); color: white; }
.step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(6,59,36,.10);
  color: var(--muted);
  font-weight: 900;
  font-size: .78rem;
  flex-shrink: 0;
}
.step-text {
  font-size: .82rem;
  font-weight: 700;
  white-space: nowrap;
}

/* -----------------------------------------
   QUOTE REQUEST SUMMARY CARD (Part J)
----------------------------------------- */
.quote-request-summary-card {
  margin-top: 20px;
  background: white;
  border: 1px solid rgba(6,59,36,.08);
  border-radius: 16px;
  padding: 18px;
}
.quote-request-summary-card h3 {
  font-size: .88rem;
  font-weight: 900;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: 0 0 14px;
}
.quote-summary-list { display: grid; gap: 10px; }
.quote-summary-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(6,59,36,.06);
}
.quote-summary-item:last-child { border-bottom: 0; padding-bottom: 0; }
.item-details { display: flex; flex-direction: column; gap: 2px; }
.item-details strong { font-size: .88rem; font-weight: 800; color: var(--forest); }
.item-pack { font-size: .74rem; color: var(--muted); font-weight: 700; }
.item-qty { font-size: .82rem; color: var(--muted); white-space: nowrap; }
.item-qty b { color: var(--forest); }
.quote-summary-totals {
  display: flex;
  gap: 20px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(6,59,36,.08);
}
.quote-summary-totals p {
  font-size: .78rem;
  color: var(--muted);
  margin: 0;
  display: flex;
  gap: 6px;
  align-items: center;
}
.quote-summary-totals span { font-weight: 900; color: var(--forest); }

/* Form 2-column row */
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* -----------------------------------------
   ACCOUNT CARD SPLIT (Part F and K)
----------------------------------------- */
.account-centered-container { max-width: 960px; margin: 0 auto; }
.account-card-split {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0;
  overflow: hidden;
  padding: 0;
  border-radius: 28px;
}
.account-card-info {
  padding: 40px 36px;
  background: linear-gradient(135deg, #031c12, var(--forest));
  color: white;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.account-card-info h1 {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -.03em;
  font-weight: 950;
  margin: 0;
  color: white;
}
.account-card-info p { color: rgba(255,255,255,.78); line-height: 1.65; margin: 0; }
.account-bullet-points { display: grid; gap: 8px; margin-top: 10px; }
.account-bullet-points p {
  font-size: .86rem;
  color: rgba(255,255,255,.82);
  margin: 0;
  padding: 8px 12px;
  background: rgba(255,255,255,.07);
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.1);
}
.account-panel {
  padding: 40px 36px;
  background: white;
  border-radius: 0;
  display: grid;
  gap: 14px;
}
.account-panel h2 {
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--forest);
  margin: 0 0 4px;
}
.account-panel label {
  display: grid;
  gap: 5px;
  font-size: .72rem;
  font-weight: 900;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.account-panel input {
  width: 100%;
  min-height: 42px;
  border: 1.5px solid rgba(6,59,36,.14);
  border-radius: 12px;
  padding: 0 14px;
  font-size: .9rem;
  background: var(--cream);
  outline: 0;
  color: var(--charcoal);
}
.account-panel input:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(15,122,58,.1); }
.forgot-row { display: flex; justify-content: flex-end; margin-top: -6px; }
.forgot-link { font-size: .8rem; color: var(--muted); text-decoration: underline; }
.forgot-link:hover { color: var(--forest); }
.account-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 10px;
  border-top: 1px solid rgba(6,59,36,.08);
}
.switch-link { font-size: .84rem; color: var(--green); font-weight: 700; text-align: center; }
.switch-link:hover { color: var(--forest); }
.back-link { color: var(--muted); font-weight: 600; }

/* -----------------------------------------
   PHASE 2 RESPONSIVE ADDITIONS (Part L)
----------------------------------------- */
@media (max-width: 1080px) {
  .account-card-split { grid-template-columns: 1fr; }
  .account-card-info { padding: 28px 24px; }
  .account-panel { padding: 28px 24px; }
  .quote-progress-tracker { overflow-x: auto; }
  .tracker-step { min-width: 100px; }
}
@media (max-width: 680px) {
  .campaign-container { grid-template-columns: 1fr 1fr; }
  .campaign-item:last-child { grid-column: span 2; border-bottom: 0; }
  .quote-progress-tracker { border-radius: 12px; }
  .tracker-step { padding: 10px 12px; gap: 6px; }
  .step-text { font-size: .72rem; }
  .form-row { grid-template-columns: 1fr; }
  .quote-summary-totals { flex-direction: column; gap: 8px; }
  .account-card-split { border-radius: 20px; }
}
@media (max-width: 480px) {
  .campaign-container { grid-template-columns: 1fr; }
}

/* =========================================
   PREMIUM WORKSPACE / DASHBOARD STYLES
   ========================================= */
:root {
  --ws-bg: #FAF9F6;
  --ws-card: #FFFFFF;
  --ws-forest: #052014;
  --ws-green: #0B6B3A;
  --ws-mint: #E8F5EE;
  --ws-mint-text: #0B5C32;
  --ws-gold: #B0892B;
  --ws-gold-light: #F7F3E8;
  --ws-border: rgba(5, 32, 20, 0.07);
  --ws-shadow: 0 10px 30px rgba(5, 32, 20, 0.03);
}

.workspace-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  height: 100vh;
  width: 100vw;
  overflow: hidden;
  background: var(--ws-bg);
  color: var(--charcoal);
  font-family: Inter, sans-serif;
}

.workspace-sidebar {
  background: var(--ws-forest);
  color: rgba(255, 255, 255, 0.85);
  display: flex;
  flex-direction: column;
  height: 100%;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  z-index: 50;
  overflow-y: auto;
}

.workspace-sidebar-brand {
  padding: 24px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.workspace-sidebar-menu {
  padding: 16px;
  flex: 1;
}

.workspace-menu-group {
  margin-bottom: 24px;
}

.workspace-menu-title {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255, 255, 255, 0.4);
  font-weight: 800;
  margin-bottom: 8px;
  padding-left: 12px;
}

.workspace-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 0.88rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.75);
  transition: all 0.2s ease;
  margin-bottom: 2px;
}

.workspace-menu-item:hover {
  color: #FFFFFF;
  background: rgba(255, 255, 255, 0.06);
}

.workspace-menu-item.active {
  color: #FFFFFF;
  background: var(--ws-green);
  box-shadow: 0 4px 12px rgba(11, 107, 58, 0.2);
}

.workspace-menu-item.active-gold {
  color: #FFFFFF;
  background: var(--ws-gold);
  box-shadow: 0 4px 12px rgba(176, 137, 43, 0.25);
}

.workspace-topbar {
  background: #FFFFFF;
  height: 76px;
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--ws-border);
  position: relative;
  z-index: 30;
  box-shadow: 0 2px 10px rgba(5, 32, 20, 0.015);
}

.workspace-topbar-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.workspace-breadcrumbs {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.workspace-page-title {
  font-size: 1.4rem;
  font-weight: 850;
  color: var(--charcoal);
  letter-spacing: -0.02em;
}

.workspace-topbar-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.workspace-icon-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  background: transparent;
  border: 1px solid var(--ws-border);
  transition: all 0.2s;
  position: relative;
  cursor: pointer;
}

.workspace-icon-btn:hover {
  background: var(--ws-bg);
  color: var(--charcoal);
  border-color: rgba(5, 32, 20, 0.12);
}

.workspace-icon-btn .badge {
  position: absolute;
  top: 0;
  right: 0;
  width: 8px;
  height: 8px;
  background: var(--ws-gold);
  border-radius: 50%;
}

.workspace-profile-trigger {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--ws-border);
  background: transparent;
  cursor: pointer;
  transition: all 0.2s;
}

.workspace-profile-trigger:hover {
  background: var(--ws-bg);
  border-color: rgba(5, 32, 20, 0.12);
}

.workspace-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--ws-green);
  color: #FFFFFF;
  font-weight: 800;
  font-size: 0.88rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
  border: 2px solid #FFFFFF;
  box-shadow: 0 0 0 1px var(--ws-green);
}

.workspace-user-name {
  font-size: 0.88rem;
  font-weight: 750;
  color: var(--charcoal);
}

.workspace-dropdown-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 32px;
  background: #FFFFFF;
  border: 1px solid var(--ws-border);
  border-radius: 16px;
  min-width: 220px;
  padding: 8px;
  box-shadow: 0 12px 35px rgba(5, 32, 20, 0.1);
  display: none;
  z-index: 100;
  transform: translateY(4px);
  transition: opacity 0.18s, transform 0.18s;
}

.workspace-dropdown-panel.open {
  display: block;
}

.workspace-dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--charcoal);
  cursor: pointer;
  transition: all 0.15s;
}

.workspace-dropdown-item:hover {
  background: var(--ws-bg);
  color: var(--ws-forest);
}

.workspace-main-wrapper {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.workspace-content {
  flex: 1;
  padding: 32px;
  overflow-y: auto;
  background: var(--ws-bg);
}

.workspace-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}

.workspace-card {
  background: var(--ws-card);
  border-radius: 20px;
  border: 1px solid var(--ws-border);
  box-shadow: var(--ws-shadow);
  padding: 24px;
  position: relative;
  overflow: hidden;
}

.workspace-section-card {
  background: rgba(255,255,255,.82);
  border: 1px solid var(--ws-border);
  box-shadow: var(--ws-shadow);
  backdrop-filter: blur(12px);
}

.workspace-mini-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(15,122,58,.1);
  color: var(--ws-forest);
  font-size: .78rem;
  font-weight: 900;
  border: 1px solid rgba(15,122,58,.14);
}

.workspace-form-field {
  width: 100%;
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid var(--ws-border);
  background: rgba(255,255,255,.9);
  padding: 10px 14px;
  color: var(--charcoal);
  outline: none;
}

.workspace-form-field:focus {
  border-color: rgba(15,122,58,.5);
  box-shadow: 0 0 0 4px rgba(15,122,58,.08);
}

.workspace-checkbox-list label {
  display: block;
  margin: 6px 0;
  font-weight: 800;
  color: var(--charcoal);
}

.workspace-content .status-pill {
  background: rgba(15,122,58,.1);
  color: var(--ws-forest);
}

.workspace-kpi {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 120px;
}

.workspace-kpi-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.workspace-kpi-label {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.workspace-kpi-value {
  font-size: 2.1rem;
  font-weight: 900;
  color: var(--ws-forest);
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.workspace-kpi-trend {
  font-size: 0.76rem;
  font-weight: 700;
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 4px;
}

.workspace-kpi-trend.up { color: var(--ws-green); }
.workspace-kpi-trend.down { color: var(--ws-gold); }
.workspace-kpi-trend.neutral { color: var(--muted); }

.workspace-pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 99px;
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.workspace-pill.pill-green {
  background: var(--ws-mint);
  color: var(--ws-mint-text);
}

.workspace-pill.pill-gold {
  background: var(--ws-gold-light);
  color: var(--ws-gold);
}

.workspace-pill.pill-neutral {
  background: #EFEFEF;
  color: #555555;
}

.workspace-pill.pill-primary {
  background: #E8EEFB;
  color: #1A56DB;
}

.workspace-action-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 180px;
  transition: all 0.25s ease;
  border: 1px solid var(--ws-border);
}

.workspace-action-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 15px 35px rgba(5, 32, 20, 0.06);
  border-color: rgba(11, 107, 58, 0.2);
}

.workspace-action-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--ws-gold-light);
  color: var(--ws-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  font-weight: 800;
}

.workspace-action-card:hover .workspace-action-icon {
  background: var(--ws-mint);
  color: var(--ws-green);
}

.workspace-action-title {
  font-size: 1.08rem;
  font-weight: 800;
  color: var(--ws-forest);
  margin-bottom: 6px;
}

.workspace-action-desc {
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 16px;
}

/* Charts */
.ws-chart-donut-container {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: conic-gradient(
    var(--ws-green) 0% 45%,
    var(--ws-gold) 45% 75%,
    #E2E8F0 75% 100%
  );
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: inset 0 2px 5px rgba(0,0,0,0.06);
}

.ws-chart-donut-inner {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: #FFFFFF;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(5, 32, 20, 0.04);
}

.ws-chart-progress {
  height: 8px;
  border-radius: 99px;
  background: #E2E8F0;
  overflow: hidden;
  margin: 6px 0;
}

.ws-chart-progress-bar {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--ws-green), var(--ws-gold));
  transition: width 0.8s ease-out;
}

.workspace-table-container {
  overflow-x: auto;
}

.workspace-table {
  width: 100%;
  border-collapse: collapse;
}

.workspace-table th {
  background: var(--ws-bg);
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 14px 18px;
  border-bottom: 1px solid var(--ws-border);
}

.workspace-table td {
  padding: 16px 18px;
  border-bottom: 1px solid var(--ws-border);
  font-size: 0.86rem;
  color: var(--charcoal);
  font-weight: 650;
  vertical-align: middle;
}

.workspace-table tr:hover td {
  background: rgba(5, 32, 20, 0.01);
}

/* Timeline */
.ws-timeline {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  padding-left: 20px;
}

.ws-timeline:before {
  content: "";
  position: absolute;
  left: 5px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: var(--ws-border);
}

.ws-timeline-item {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ws-timeline-dot {
  position: absolute;
  left: -20px;
  top: 4px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #E2E8F0;
  border: 2px solid #FFFFFF;
  box-shadow: 0 0 0 1px #CBD5E1;
  transition: all 0.2s;
}

.ws-timeline-item.completed .ws-timeline-dot {
  background: var(--ws-green);
  box-shadow: 0 0 0 1px var(--ws-green);
}

.ws-timeline-item.active .ws-timeline-dot {
  background: var(--ws-gold);
  box-shadow: 0 0 0 3px rgba(176, 137, 43, 0.2);
}

.ws-timeline-title {
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--charcoal);
}

.ws-timeline-date {
  font-size: 0.74rem;
  color: var(--muted);
}

/* Responsive Mobile Drawer */
.workspace-hamburger {
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  border: 1px solid var(--ws-border);
  background: #FFFFFF;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  color: var(--ws-forest);
}

.workspace-mobile-drawer {
  position: fixed;
  inset: 0;
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.workspace-mobile-drawer.open {
  opacity: 1;
  visibility: visible;
}

.workspace-mobile-overlay {
  position: absolute;
  inset: 0;
  background: rgba(5, 32, 20, 0.6);
  backdrop-filter: blur(4px);
}

.workspace-mobile-content {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 290px;
  background: var(--ws-forest);
  transform: translateX(-100%);
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
}

.workspace-mobile-drawer.open .workspace-mobile-content {
  transform: translateX(0);
}

/* Responsiveness overrides */
@media (max-width: 1024px) {
  .workspace-layout {
    grid-template-columns: 1fr;
  }
  .workspace-sidebar-desktop {
    display: none;
  }
  .workspace-hamburger {
    display: flex;
  }
  .workspace-topbar {
    padding: 0 20px;
  }
  .workspace-content {
    padding: 20px;
  }
}

@media (max-width: 768px) {
  .workspace-grid {
    gap: 16px;
  }
  .ws-span-mobile-12 {
    grid-column: span 12 !important;
  }
  .workspace-kpi {
    min-height: 100px;
  }
  .workspace-kpi-value {
    font-size: 1.8rem;
  }
}

@media (max-width: 1180px) {
  .workspace-body { grid-template-columns: 1fr; }
  .workspace-sidebar { position: fixed; left: 0; top: 0; width: min(320px, calc(100vw - 42px)); transform: translateX(-105%); transition: transform .24s ease; box-shadow: 0 28px 80px rgba(0,0,0,.32); }
  .workspace-sidebar.open { transform: translateX(0); }
  .workspace-backdrop { position: fixed; inset: 0; z-index: 80; background: rgba(3,24,16,.45); backdrop-filter: blur(4px); }
  .workspace-backdrop.open { display: block; }
  .workspace-menu-btn { display: block; }
  .workspace-topbar { align-items: center; }
  .workspace-kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .workspace-filter-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .workspace-topbar { gap: 10px; padding: 12px; }
  .workspace-user-meta { display: none; }
  .workspace-content { padding: 14px; }
  .workspace-hero-card, .workspace-page-head, .workspace-panel-head { display: block; }
  .workspace-hero-actions { margin-top: 18px; }
  .workspace-kpi-grid, .workspace-action-grid, .workspace-filter-panel, .workspace-form-grid, .workspace-report-card { grid-template-columns: 1fr; }
  .workspace-grid { grid-template-columns: 1fr; }
  .workspace-grid > * { grid-column: 1 / -1 !important; }
  .workspace-activity-list a { grid-template-columns: 1fr; }
  .workspace-table-wrap { display: none; }
  .workspace-quote-cards { display: grid; gap: 12px; }
  .workspace-bar-grid div { grid-template-columns: 1fr; gap: 6px; }
  .workspace-hero-card h2, .workspace-page-head h2 { font-size: 2rem; }
}

/* Scoped Workspace Management CSS (Phase 2) */
.workspace-management-page {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.workspace-page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  border-bottom: 1px solid var(--ws-border);
  padding-bottom: 16px;
  margin-bottom: 8px;
}

.workspace-page-header h2 {
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--ws-forest);
  letter-spacing: -0.03em;
}

.workspace-filterbar {
  background: var(--ws-card);
  border: 1px solid var(--ws-border);
  border-radius: 16px;
  padding: 16px 20px;
  box-shadow: var(--ws-shadow);
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 16px;
}

.workspace-management-table {
  width: 100%;
  border-collapse: collapse;
}

.workspace-management-table th {
  background: #FAF9F6;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 12px 16px;
  border-bottom: 1px solid var(--ws-border);
  text-align: left;
}

.workspace-management-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--ws-border);
  font-size: 0.84rem;
  color: var(--charcoal);
  font-weight: 600;
  vertical-align: middle;
}

.workspace-management-table tr:hover td {
  background: rgba(5, 32, 20, 0.015);
}

.workspace-mobile-card {
  background: var(--ws-card);
  border: 1px solid var(--ws-border);
  border-radius: 16px;
  padding: 16px;
  box-shadow: var(--ws-shadow);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.workspace-form-card {
  background: var(--ws-card);
  border: 1px solid var(--ws-border);
  border-radius: 20px;
  box-shadow: var(--ws-shadow);
  padding: 24px;
}

.workspace-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px 24px;
  background: var(--ws-card);
  border: 2px dashed rgba(5, 32, 20, 0.1);
  border-radius: 20px;
  color: var(--muted);
}

.workspace-empty-state svg {
  color: var(--ws-gold);
  opacity: 0.75;
  margin-bottom: 16px;
}

.workspace-empty-state h3 {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--ws-forest);
  margin-bottom: 6px;
}

.workspace-empty-state p {
  font-size: 0.84rem;
  max-width: 320px;
  margin-bottom: 16px;
}

.workspace-role-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.role-admin { background: #FDE8E8; color: #9B1C1C; }
.role-sales { background: #E1EFFE; color: #1E429F; }
.role-exec { background: #FEF08A; color: #713F12; }
.role-buyer { background: #E8F5EE; color: #0B5C32; }

.workspace-permission-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 0.7rem;
  font-weight: 700;
  background: #F3F4F6;
  color: #374151;
  border: 1px solid #E5E7EB;
}

.workspace-image-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
}

.workspace-image-card {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--ws-border);
  background: var(--ws-card);
  aspect-ratio: 1;
}

.workspace-image-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.workspace-report-panel {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}

.workspace-warning-panel {
  background: #FFFDF5;
  border-left: 4px solid var(--ws-gold);
  padding: 16px;
  border-radius: 8px;
  color: #713F12;
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.5;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.workspace-warning-panel svg {
  color: var(--ws-gold);
  flex-shrink: 0;
}

.workspace-actionbar {
  background: var(--ws-card);
  border-top: 1px solid var(--ws-border);
  padding: 16px 24px;
  margin: 0 -24px -24px -24px;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

/* Scoped Workspace CSS extensions for Invoices, Pricing, Payments, Notifications */
.workspace-invoice-page {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.workspace-money-card {
  background: #FFFFFF;
  border: 1px solid var(--ws-border, rgba(16, 37, 26, 0.08));
  border-radius: 20px;
  padding: 20px;
  box-shadow: var(--ws-shadow, 0 10px 30px rgba(5, 32, 20, 0.04));
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 120px;
}

.workspace-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 99px;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.status-draft { background: #E5E7EB; color: #374151; }
.status-sent { background: #FEF3C7; color: #D97706; }
.status-accepted { background: #D1FAE5; color: #059669; }
.status-rejected { background: #FEE2E2; color: #DC2626; }
.status-cancelled { background: #F3F4F6; color: #6B7280; }

.workspace-invoice-document {
  background: #FFFFFF;
  border: 1px solid rgba(16, 37, 26, 0.08);
  box-shadow: 0 15px 45px rgba(5, 32, 20, 0.06);
  border-radius: 24px;
  padding: 40px;
  max-width: 840px;
  margin: 0 auto;
  color: #10251a;
}

.workspace-document-table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
}

.workspace-document-table th {
  background: #FAF9F6;
  border-bottom: 2px solid #0f7a3a;
  color: #5e6f64;
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 12px 14px;
  text-align: left;
}

.workspace-document-table td {
  padding: 14px;
  border-bottom: 1px solid #E5E7EB;
  font-size: 0.88rem;
}

/* Timeline */
.workspace-timeline {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
  padding-left: 24px;
}

.workspace-timeline::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 6px;
  bottom: 6px;
  width: 2px;
  background: #E5E7EB;
}

.workspace-timeline-item {
  position: relative;
}

.workspace-timeline-dot {
  position: absolute;
  left: -22px;
  top: 4px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #E5E7EB;
  border: 3px solid #FFFFFF;
  box-shadow: 0 0 0 1px #D1D5DB;
}

.workspace-timeline-item.active .workspace-timeline-dot {
  background: #0f7a3a;
  box-shadow: 0 0 0 3px rgba(15, 122, 58, 0.18);
}

.workspace-pricing-page, .workspace-payment-page, .workspace-notifications-page {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.workspace-warning-panel {
  background: #FFFDF5;
  border-left: 4px solid #d6a93a;
  border-radius: 12px;
  padding: 16px 20px;
  color: #713F12;
  font-size: 0.84rem;
  font-weight: 600;
  line-height: 1.5;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.workspace-empty-state {
  background: #FFFFFF;
  border: 2px dashed rgba(16, 37, 26, 0.12);
  border-radius: 24px;
  padding: 48px 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.workspace-empty-state h3 {
  font-size: 1.2rem;
  font-weight: 800;
  color: #063b24;
  margin: 12px 0 6px;
}

.workspace-empty-state p {
  color: #5e6f64;
  font-size: 0.88rem;
  max-width: 380px;
  margin-bottom: 20px;
}

.workspace-mobile-card {
  background: #FFFFFF;
  border: 1px solid rgba(16, 37, 26, 0.08);
  border-radius: 16px;
  padding: 16px;
  margin-bottom: 12px;
  box-shadow: 0 4px 15px rgba(5, 32, 20, 0.02);
}

@media print {
  body {
    background: #FFFFFF !important;
    color: #000000 !important;
  }
  .workspace-layout, .workspace-topbar, .workspace-sidebar, .workspace-hamburger, .message-stack, .btn-primary, .btn-secondary, .no-print, header, aside, .message-stack {
    display: none !important;
  }
  .workspace-main-wrapper {
    margin: 0 !important;
    padding: 0 !important;
  }
  .workspace-invoice-document {
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
  }
}

/* Workspace sidebar notification badge */
.workspace-menu-badge {
  margin-left: auto;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--gold-2);
  color: #1f1a0d;
  font-size: 0.68rem;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Email CTA destination banners (workspace) */
.email-action-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 22px;
  border-radius: 20px;
  background: linear-gradient(135deg, #faf7ef, #e8f5ee);
  border: 1px solid rgba(176, 137, 43, 0.28);
  box-shadow: 0 12px 32px rgba(6, 59, 36, 0.08);
}
.email-action-banner-staff {
  background: linear-gradient(135deg, #e8f5ee, #ffffff);
  border-color: rgba(15, 122, 58, 0.22);
}
.email-action-banner-quote {
  background: linear-gradient(135deg, #f7f3e8, #ffffff);
}
.email-action-eyebrow {
  display: block;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
}
.email-action-banner h2 {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 900;
  color: var(--forest);
  letter-spacing: -0.02em;
}
.email-action-banner p {
  margin: 6px 0 0;
  font-size: 0.82rem;
  color: var(--muted);
  max-width: 52ch;
  line-height: 1.55;
}
.email-action-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
  color: #1f1a0d;
  font-weight: 900;
  font-size: 0.82rem;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(93, 68, 11, 0.18);
  text-decoration: none;
  white-space: nowrap;
}
.email-action-cta-secondary {
  background: linear-gradient(135deg, var(--green), var(--forest));
  color: white;
  box-shadow: 0 12px 28px rgba(6, 59, 36, 0.18);
}
button.email-action-cta:hover,
a.email-action-cta:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}

/* Responsive workspace tables */
.workspace-table-container {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0 -4px;
  padding: 0 4px;
}
.workspace-table {
  min-width: 520px;
}

/* Prevent horizontal page overflow */
html, body {
  overflow-x: hidden;
}
.workspace-content {
  overflow-x: hidden;
  max-width: 100%;
}

@media (max-width: 768px) {
  .workspace-topbar {
    padding: 0 16px;
    height: auto;
    min-height: 76px;
    flex-wrap: wrap;
    gap: 10px;
  }
  .workspace-topbar-right {
    gap: 10px;
  }
  .workspace-user-name {
    display: none !important;
  }
  .email-action-banner {
    flex-direction: column;
    align-items: stretch;
  }
  .email-action-cta {
    width: 100%;
  }
  .workspace-layout {
    width: 100%;
    max-width: 100vw;
  }
}

@media (min-width: 1440px) {
  .workspace-content {
    max-width: min(1320px, calc(100% - 48px));
    margin-inline: auto;
  }
}

.invoice-total-highlight {
  border: 1px solid rgba(176, 137, 43, 0.22);
  background: linear-gradient(145deg, #faf7ef, #ffffff);
}

.ws-timeline-item.active .ws-timeline-dot,
.workspace-timeline-item.active .workspace-timeline-dot {
  box-shadow: 0 0 0 4px rgba(176, 137, 43, 0.25);
}
