.cp-root { scrollbar-width: thin; scrollbar-color: var(--cp-acc) transparent; }
.cp-root *::-webkit-scrollbar { width: 6px; height: 6px; }
.cp-root *::-webkit-scrollbar-track { background: transparent; }
.cp-root *::-webkit-scrollbar-thumb { background: var(--cp-acc); border-radius: 10px; }
.cp-root *::-webkit-scrollbar-thumb:hover { filter: brightness(1.2); }
html::-webkit-scrollbar { width: 6px; }
html::-webkit-scrollbar-track { background: transparent; }
html::-webkit-scrollbar-thumb { background: var(--cp-acc, #C9A84C); border-radius: 10px; }
.cp-root *{box-sizing:border-box}
.cp-root{display:flex;flex-direction:column;min-height:100vh;background:var(--cp-bg);color:var(--cp-text);font-size:14px}

/* ── Header ── */
.cp-header{display:flex;align-items:center;gap:16px;padding:0 20px;height:56px;position:sticky;top:0;z-index:100;flex-shrink:0}
.cp-header-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.cp-logo-placeholder{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}
.cp-header-search{flex:1;max-width:480px;display:flex;align-items:center;gap:8px;background:rgba(128,128,128,0.08);border:1px solid var(--cp-border);border-radius:8px;padding:0 12px;height:36px}
.cp-busca-input{flex:1;background:none;border:none;outline:none;font-size:13px;color:var(--cp-text)}
.cp-busca-input::placeholder{color:var(--cp-sub)}
.cp-busca-clear{background:none;border:none;cursor:pointer;color:var(--cp-sub);font-size:14px;padding:0;flex-shrink:0}
.cp-header-actions{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.cp-header-cart{display:flex;align-items:center;gap:8px;border:none;border-radius:50px;padding:8px 16px;font-size:13px;cursor:pointer;font-family:inherit;font-weight:700;transition:opacity 0.15s}.cp-header-cart:hover{opacity:0.85}
.cp-cart-badge{border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700}
.cp-mobile-menu-btn{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:4px}
.cp-mobile-menu-btn span{display:block;width:20px;height:2px;background:currentColor;border-radius:2px}

/* ── Body ── */
.cp-body{display:grid;grid-template-columns:220px 1fr;flex:1;min-height:0}

/* ── Sidebar ── */
.cp-sidebar{position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;display:flex;flex-direction:column;padding:16px 10px;gap:2px}
.cp-sidebar-close{display:none;background:none;border:none;cursor:pointer;font-size:20px;padding:0;align-self:flex-end;margin-bottom:8px}
.cp-nav-section-label{font-size:10px;text-transform:uppercase;letter-spacing:0.08em;padding:0 8px;margin:8px 0 4px}
.cp-nav-section-label:first-child{margin-top:0}
.cp-nav{display:flex;flex-direction:column;gap:2px}
.cp-nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;background:none;border:none;cursor:pointer;font-size:13px;text-align:left;width:100%;font-family:inherit;transition:background 0.15s}
.cp-nav-item:hover{opacity:0.85}
.cp-nav-icon{font-size:10px;flex-shrink:0}
.cp-nav-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cp-nav-count{display:none}
.cp-nav-subitem{font-size:12px!important;padding:6px 10px!important}
.cp-sidebar-cart-btn{display:flex;align-items:center;gap:10px;padding:12px;border-radius:10px;border:1px solid var(--cp-border);background:rgba(128,128,128,0.04);cursor:pointer;font-family:inherit;margin-top:auto;width:100%;text-align:left}
.cp-sidebar-cart-icon{position:relative;font-size:18px;flex-shrink:0}
.cp-sidebar-cart-info{flex:1;min-width:0}
.cp-sidebar-cart-info strong{display:block;font-size:13px;font-weight:700}
.cp-sidebar-cart-info span{font-size:12px}
.cp-ghostsys{display:flex;align-items:center;gap:4px;justify-content:center;padding:16px 0 8px;opacity:0.3;font-size:11px;margin-top:auto;padding-top:24px}
.cp-ghostsys strong{font-weight:700}

/* ── Main ── */
.cp-main{padding:24px 28px;display:flex;flex-direction:column;gap:0;min-width:0}
.cp-secao{margin-bottom:32px}
.cp-secao-header{display:flex;align-items:baseline;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--cp-border)}
.cp-cat-titulo{font-size:16px;font-weight:700;margin:0}
.cp-cat-count{font-size:12px;color:var(--cp-sub)}
.cp-vazio{font-size:13px;grid-column:1/-1;padding:24px 0}

/* ── Grid ── */
.cp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}

/* ── Card ── */
.cp-card{border-radius:12px;border:1px solid var(--cp-border);overflow:hidden;display:flex;flex-direction:column;transition:transform 0.15s,border-color 0.15s}
.cp-card:hover{transform:translateY(-2px);border-color:rgba(128,128,128,0.3)}
.cp-card-anim{transform:scale(1.02)}
.cp-card-img{height:190px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:rgba(128,128,128,0.05);position:relative}
.cp-card-img-placeholder{font-size:48px;opacity:0.3}
.cp-card-badge-qty{position:absolute;top:8px;right:8px;font-size:10px;font-weight:700;border-radius:10px;padding:2px 8px}
.cp-card-body{padding:12px;display:flex;flex-direction:column;gap:5px;flex:1;min-height:120px}
.cp-card-cat{font-size:10px;text-transform:uppercase;letter-spacing:0.06em;font-weight:600;opacity:0.5}
.cp-card-nome{font-size:13px;font-weight:600;line-height:1.4;flex:1}
.cp-card-preco{font-size:16px;font-weight:700}
.cp-card-desc{font-size:12px;opacity:0.6;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cp-card-btn{width:100%;padding:9px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:700;font-family:inherit;transition:opacity 0.15s}
.cp-card-btn:hover{opacity:0.85}

/* ── Modal ── */
.cp-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:300;display:flex;align-items:center;justify-content:center;padding:16px}

/* ── FAB ── */
.cp-fab{position:fixed;bottom:24px;right:24px;border:none;border-radius:50px;padding:14px 22px;font-size:15px;cursor:pointer;display:flex;align-items:center;gap:8px;z-index:200;font-family:inherit;font-weight:700}
.cp-fab-badge{border-radius:10px;padding:1px 8px;font-size:12px;background:rgba(255,255,255,0.2)}
.cp-fab-total{font-size:13px;opacity:0.9}

/* ── Drawer ── */
.cp-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:400;display:flex;justify-content:flex-end}
.cp-drawer{width:min(380px,100vw);height:100%;display:flex;flex-direction:column}
.cp-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px}
.cp-drawer-header h3{font-size:16px;font-weight:700;margin:0}
.cp-drawer-close{background:none;border:none;cursor:pointer;font-size:20px;padding:0}
.cp-drawer-vazio{flex:1;display:flex;align-items:center;justify-content:center;font-size:14px}
.cp-drawer-items{flex:1;overflow-y:auto;padding:12px 20px;display:flex;flex-direction:column;gap:12px}
.cp-drawer-item{display:flex;align-items:center;gap:10px}
.cp-drawer-item-img{width:52px;height:52px;border-radius:8px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px}
.cp-drawer-item-img img{width:100%;height:100%;object-fit:cover}
.cp-drawer-item-info{flex:1;min-width:0}
.cp-drawer-item-nome{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cp-drawer-item-preco{font-size:12px}
.cp-drawer-qty{display:flex;align-items:center;gap:6px;flex-shrink:0}
.cp-drawer-qty button{width:24px;height:24px;border-radius:6px;border:1px solid var(--cp-border);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}
.cp-drawer-qty span{font-size:13px;font-weight:700;min-width:20px;text-align:center}
.cp-drawer-remove{background:none;border:none;cursor:pointer;font-size:16px;padding:4px;flex-shrink:0}
.cp-drawer-total{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;font-size:14px}
.cp-drawer-total strong{font-size:18px;font-weight:700}
.cp-drawer-wpp{margin:0 20px 20px;padding:14px;border-radius:10px;border:none;cursor:pointer;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit}
.cp-drawer-wpp:disabled{opacity:0.5;cursor:not-allowed}
.cp-drawer-wpp-hint{text-align:center;font-size:12px;padding:0 20px 12px}

/* ── Footer ── */
.cp-footer{margin-top:auto;padding:24px 0 8px;display:flex;align-items:center;gap:4px}

/* ── Loading/Erro ── */
.cp-fullscreen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}
.cp-loading{opacity:0.5}
.cp-spinner-big{width:36px;height:36px;border:3px solid rgba(128,128,128,0.2);border-top-color:currentColor;border-radius:50%;animation:cp-spin 0.8s linear infinite}
@keyframes cp-spin{to{transform:rotate(360deg)}}
.cp-erro{color:#ef4444}

/* ── Mobile ── */
@media(max-width:720px){
  .cp-header{padding:0 14px;gap:10px}
  .cp-header-search{max-width:none;flex:1}
  .cp-mobile-menu-btn{display:flex}
  .cp-body{grid-template-columns:1fr}
  .cp-sidebar{display:none;position:fixed;top:0;left:0;height:100%;width:260px;z-index:200;padding:16px 12px}
  .cp-sidebar.aberta{display:flex}
  .cp-sidebar-close{display:block}
  .cp-main{padding:14px}
  .cp-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
  .cp-fab{bottom:16px;right:16px;padding:12px 18px;font-size:14px}
}
