/* ============================================================
   Product Category Tabs — style.css v11.0
   ============================================================ */

#pct-wrapper {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 16px 60px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Tabs */
#pct-tabs { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:30px; }
.pct-tab {
    background:#fff; border:2px solid #ddd; border-radius:50px;
    color:#444; cursor:pointer; font-size:15px; font-weight:600;
    padding:10px 26px; transition:all 0.2s;
}
.pct-tab:hover { border-color:#333; color:#111; }
.pct-tab.active { background:#222; border-color:#222; color:#fff; }

/* Grid */
#pct-grid { display:grid; gap:22px; transition:opacity 0.2s; }
.pct-cols-1 { grid-template-columns:1fr; }
.pct-cols-2 { grid-template-columns:repeat(2,1fr); }
.pct-cols-3 { grid-template-columns:repeat(3,1fr); }
.pct-cols-4 { grid-template-columns:repeat(4,1fr); }
@media(max-width:860px){ .pct-cols-3,.pct-cols-4{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:540px){ #pct-grid{ grid-template-columns:1fr !important; } }

/* Loading */
#pct-loading { text-align:center; padding:50px 0; }
.pct-spinner {
    display:inline-block; width:40px; height:40px;
    border:4px solid #eee; border-top-color:#333; border-radius:50%;
    animation:pct-spin 0.7s linear infinite;
}
@keyframes pct-spin { to { transform:rotate(360deg); } }

/* Card */
.pct-card {
    background:#fff; border-radius:14px;
    box-shadow:0 2px 14px rgba(0,0,0,.08); overflow:hidden;
    display:flex; flex-direction:column;
    transition:box-shadow 0.2s,transform 0.2s;
    animation:pct-fadein 0.3s ease both;
}
.pct-card:hover { box-shadow:0 6px 28px rgba(0,0,0,.13); transform:translateY(-3px); }
@keyframes pct-fadein { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

.pct-card-img { position:relative; width:100%; padding-top:100%; background:#f7f7f7; overflow:hidden; }
.pct-card-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 0.3s; }
.pct-card:hover .pct-card-img img { transform:scale(1.05); }

.pct-badge {
    position:absolute; top:10px; left:10px; background:#111; color:#fff;
    font-size:10px; font-weight:800; letter-spacing:.07em;
    padding:4px 10px; border-radius:50px; text-transform:uppercase; z-index:1;
}

.pct-card-body { padding:16px 18px 18px; display:flex; flex-direction:column; flex:1; }
.pct-card-body h3 { font-size:16px; font-weight:700; margin:0 0 8px; line-height:1.3; color:#111; }
.pct-card-body h3 a { color:inherit; text-decoration:none; }
.pct-card-body h3 a:hover { text-decoration:underline; }
.pct-desc {
    font-size:13px; color:#777; line-height:1.55; margin:0 0 14px; flex:1;
    display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

.pct-card-footer { display:flex; align-items:center; justify-content:space-between; gap:8px; margin-top:auto; }
.pct-price { font-size:17px; font-weight:800; color:#111; }
.pct-price .woocommerce-Price-amount { font-size:17px; font-weight:800; color:#111; }

.pct-card-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; }

/* Add to cart button */
.pct-add-btn {
    position:relative; display:inline-flex; align-items:center; justify-content:center;
    background:#222; border:none; border-radius:50px; color:#fff;
    cursor:pointer; padding:10px 16px; transition:background 0.18s,transform 0.15s; flex-shrink:0;
}
.pct-add-btn:hover { background:#000; }
.pct-add-btn:disabled { opacity:0.6; cursor:not-allowed; }
.pct-add-btn svg { display:block; flex-shrink:0; }

/* Ingredient icon button */
.pct-ing-btn {
    display:inline-flex; align-items:center; justify-content:center;
    background:#fff; border:2px solid #e0e0e0; border-radius:50%;
    color:#555; cursor:pointer; width:40px; height:40px;
    transition:border-color 0.18s,color 0.18s; flex-shrink:0;
}
.pct-ing-btn:hover { border-color:#e53935; color:#e53935; background:#fff5f5; }
.pct-ing-btn svg { display:block; }

.pct-oos { font-size:12px; color:#bbb; font-style:italic; }
.pct-empty { grid-column:1/-1; text-align:center; color:#aaa; padding:40px; }

/* Variable product — View Options link */
.pct-view-btn {
    display:inline-flex; align-items:center;
    background:#fff; border:2px solid #222; border-radius:50px;
    color:#222; cursor:pointer; font-size:13px; font-weight:700;
    padding:8px 14px; text-decoration:none; white-space:nowrap;
    transition:background 0.18s, color 0.18s; flex-shrink:0;
}
.pct-view-btn:hover { background:#222; color:#fff; text-decoration:none; }

/* Options badge variant */
.pct-badge--options { background:#555; left:auto; right:10px; }

/* ============================================================
   FLOATING CART BUBBLE
   Server-rendered by PHP, replaced by WC fragment after add.
   Hidden at count=0, shown via --visible modifier.
   ============================================================ */
.pct-floating-cart {
    position:fixed; bottom:30px; right:30px; z-index:9000;
    display:none; /* hidden until items added */
}
.pct-floating-cart--visible { display:block; }

#pct-cart-btn {
    background:#e53935; border:none; border-radius:50%;
    width:64px; height:64px; color:#fff; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 4px 20px rgba(229,57,53,.5);
    transition:transform 0.2s,box-shadow 0.2s;
    animation:pct-popin 0.35s cubic-bezier(.175,.885,.32,1.275) both;
    position:relative;
}
@keyframes pct-popin { from{transform:scale(0);opacity:0} to{transform:scale(1);opacity:1} }
#pct-cart-btn:hover { transform:scale(1.12); box-shadow:0 6px 28px rgba(229,57,53,.6); }

#pct-cart-count {
    position:absolute; top:-5px; right:-5px;
    background:#fff; color:#e53935; border:2px solid #e53935;
    border-radius:50%; font-size:12px; font-weight:800;
    min-width:22px; height:22px;
    display:flex; align-items:center; justify-content:center;
    padding:0 3px; line-height:1;
}

/* ============================================================
   OVERLAY
   ============================================================ */
#pct-overlay {
    display:none; position:fixed; inset:0;
    background:rgba(0,0,0,.5); z-index:9100;
}
#pct-overlay.show { display:block; }

/* ============================================================
   CART DRAWER
   ============================================================ */
#pct-drawer {
    position:fixed; bottom:0; right:0; width:100%; max-width:420px;
    height:75vh; max-height:620px; background:#fff;
    border-radius:20px 20px 0 0; z-index:9200;
    display:flex; flex-direction:column;
    box-shadow:0 -4px 30px rgba(0,0,0,.15);
    transform:translateY(100%); transition:transform 0.3s ease;
}
#pct-drawer.open { transform:translateY(0); }

#pct-drawer-head {
    display:flex; align-items:center; justify-content:space-between;
    padding:20px 22px 16px; border-bottom:1px solid #f0f0f0;
    flex-shrink:0; font-size:18px; font-weight:800; color:#111;
}
#pct-drawer-close {
    background:#f0f0f0; border:none; border-radius:50%; color:#555;
    cursor:pointer; font-size:18px; width:36px; height:36px;
    display:flex; align-items:center; justify-content:center;
    transition:background 0.15s;
}
#pct-drawer-close:hover { background:#ddd; }

#pct-drawer-body { flex:1; overflow-y:auto; padding:0; }

/* WooCommerce mini-cart inside drawer */
.pct-mini-cart-wrapper { padding:0 22px; }
.pct-mini-cart-wrapper ul.woocommerce-mini-cart { list-style:none; margin:0; padding:0; }
.pct-mini-cart-wrapper .woocommerce-mini-cart-item {
    display:flex; align-items:center; gap:12px;
    padding:14px 0; border-bottom:1px solid #f5f5f5;
    font-size:14px;
}
.pct-mini-cart-wrapper .woocommerce-mini-cart-item img {
    width:58px; height:58px; border-radius:10px; object-fit:cover;
    flex-shrink:0; background:#f0f0f0;
}
.pct-mini-cart-wrapper .woocommerce-mini-cart-item a { color:#111; text-decoration:none; font-weight:600; }
.pct-mini-cart-wrapper .woocommerce-mini-cart-item a:hover { text-decoration:underline; }
.pct-mini-cart-wrapper .woocommerce-mini-cart-item .remove {
    color:#e53935; font-size:18px; text-decoration:none; margin-left:auto; flex-shrink:0;
}
.pct-mini-cart-wrapper .woocommerce-mini-cart__total { display:none; } /* total in footer */
.pct-mini-cart-wrapper .woocommerce-mini-cart__buttons { display:none; } /* use our button */
.pct-mini-cart-wrapper p.woocommerce-mini-cart__empty-message {
    text-align:center; color:#aaa; padding:40px 0; font-size:15px;
}

#pct-drawer-foot {
    border-top:1px solid #f0f0f0; padding:16px 22px 24px; flex-shrink:0;
}
#pct-drawer-total-row {
    display:flex; justify-content:space-between;
    font-size:17px; font-weight:800; color:#111; margin-bottom:14px;
}
#pct-checkout-btn {
    display:block; background:#e53935; color:#fff; text-align:center;
    text-decoration:none; font-size:16px; font-weight:800;
    padding:16px; border-radius:50px;
    transition:background 0.18s,transform 0.15s; letter-spacing:.02em;
}
#pct-checkout-btn:hover { background:#c62828; color:#fff; transform:scale(1.02); text-decoration:none; }

/* ============================================================
   INGREDIENT MODAL
   ============================================================ */
#pct-ing-overlay {
    display:none; position:fixed; inset:0;
    background:rgba(0,0,0,.5); z-index:9300;
}
#pct-ing-overlay.show { display:block; }

#pct-ing-modal {
    display:none; position:fixed; inset:0; z-index:9400;
    align-items:flex-end; justify-content:center;
}
#pct-ing-modal.open { display:flex; }

#pct-ing-modal-inner {
    background:#fff; border-radius:24px 24px 0 0; width:100%;
    max-width:480px; max-height:88vh;
    display:flex; flex-direction:column;
    box-shadow:0 -6px 40px rgba(0,0,0,.18);
    animation:pct-slideup 0.3s cubic-bezier(.4,0,.2,1) both;
    z-index:9400; position:relative;
}
@keyframes pct-slideup { from{transform:translateY(100%);opacity:0} to{transform:translateY(0);opacity:1} }

#pct-ing-modal-head {
    display:flex; align-items:flex-start; justify-content:space-between;
    padding:22px 22px 16px; border-bottom:1px solid #f0f0f0; flex-shrink:0;
}
#pct-ing-modal-product { display:flex; align-items:center; gap:14px; }
#pct-ing-modal-img { width:60px; height:60px; border-radius:12px; object-fit:cover; flex-shrink:0; }
#pct-ing-modal-name { font-size:17px; font-weight:800; color:#111; margin:0 0 4px; }
#pct-ing-modal-base-label { font-size:13px; color:#888; margin:0; }
#pct-ing-modal-close {
    background:#f0f0f0; border:none; border-radius:50%; color:#555;
    cursor:pointer; font-size:18px; width:36px; height:36px;
    display:flex; align-items:center; justify-content:center;
    transition:background 0.15s; flex-shrink:0;
}
#pct-ing-modal-close:hover { background:#e0e0e0; }
#pct-ing-modal-subtitle {
    font-size:13px; font-weight:700; color:#aaa; letter-spacing:.07em;
    text-transform:uppercase; margin:0; padding:14px 22px 6px; flex-shrink:0;
}
#pct-ing-list { flex:1; overflow-y:auto; padding:6px 22px 10px; }

.pct-ing-row {
    display:flex; align-items:center; justify-content:space-between;
    padding:13px 0; border-bottom:1px solid #f5f5f5; gap:12px;
    border-radius:8px;
}
.pct-ing-row:last-child { border-bottom:none; }
.pct-ing-row.active { background:#fff8f8; }
.pct-ing-row-name { font-size:15px; font-weight:600; color:#222; flex:1; min-width:0; }
.pct-ing-row-right { display:flex; flex-direction:column; align-items:flex-end; gap:6px; flex-shrink:0; }
.pct-ing-row-price { font-size:12px; font-weight:600; color:#999; }
.pct-ing-row.active .pct-ing-row-price { color:#e53935; }

.pct-ing-stepper {
    display:flex; align-items:center; gap:8px;
    background:#f5f5f5; border-radius:50px; padding:4px 6px;
}
.pct-ing-minus,.pct-ing-plus {
    background:#fff; border:none; border-radius:50%; color:#333;
    cursor:pointer; font-size:16px; font-weight:800;
    width:28px; height:28px; display:flex; align-items:center; justify-content:center;
    line-height:1; transition:background 0.15s,color 0.15s;
    box-shadow:0 1px 3px rgba(0,0,0,.1); flex-shrink:0;
}
.pct-ing-plus:hover  { background:#e53935; color:#fff; }
.pct-ing-minus:hover { background:#333; color:#fff; }
.pct-ing-minus:disabled { opacity:.3; cursor:not-allowed; box-shadow:none; }
.pct-ing-qty { font-size:15px; font-weight:800; color:#111; min-width:20px; text-align:center; }
.pct-ing-row.active .pct-ing-qty { color:#e53935; }

#pct-ing-modal-foot {
    border-top:1px solid #f0f0f0; padding:16px 22px 28px; flex-shrink:0;
}
#pct-ing-total-row {
    display:flex; justify-content:space-between; align-items:center;
    font-size:16px; font-weight:800; color:#111; margin-bottom:14px;
}
#pct-ing-total { color:#e53935; font-size:20px; }
#pct-ing-confirm-btn {
    display:flex; align-items:center; justify-content:center; gap:10px;
    width:100%; background:#e53935; border:none; border-radius:50px;
    color:#fff; cursor:pointer; font-size:16px; font-weight:800;
    padding:16px; transition:background 0.18s,transform 0.15s; letter-spacing:.02em;
}
#pct-ing-confirm-btn:hover { background:#c62828; transform:scale(1.02); }

@media(max-width:460px){
    #pct-drawer { max-width:100%; border-radius:16px 16px 0 0; }
    .pct-floating-cart { bottom:20px; right:20px; }
    #pct-cart-btn { width:56px; height:56px; }
    #pct-ing-modal-inner { border-radius:18px 18px 0 0; }
}
