/* =========================================================    Product Filters (Desktop + Mobile Drawer)    Light Only + FIX:    - Desktop: f-actions selalu tampil (static bottom)    - Mobile: konten filter dapat discroll    ========================================================= */  /* ========== Layout wrapper (tidak mengubah grid produk) ========== */ .product-archive.with-filters .pa-layout {   display:flex;   gap:24px;   align-items:flex-start; } .pa-main { flex:1; min-width:0; }  /* =========================================================    DESKTOP PANEL    ========================================================= */ .pa-filters {   width:300px;   background:linear-gradient(145deg,#ffffff 0%,#f8fafc 55%,#f1f5f9 100%);   border:1px solid #e2e8f0;   padding:18px 18px 12px; /* bottom dikurangi karena f-actions punya padding sendiri */   border-radius:18px;   position:sticky;   top:80px;   height:calc(100vh - 100px); /* tinggi stabil untuk inner scroll */   font-size:14px;   box-shadow:0 1px 2px rgba(0,0,0,.04),0 4px 14px rgba(15,23,42,.08);   backdrop-filter:blur(3px);   -webkit-backdrop-filter:blur(3px);   transition:box-shadow .3s, background .4s;   display:flex;   flex-direction:column;   overflow:hidden; /* cegah double scroll, inner yang scroll */ } .pa-filters::before {   content:"";   position:absolute;   inset:0 auto 0 0;   width:7px;   border-radius:18px 0 0 18px;   background:linear-gradient(180deg,#f59e0b 0%,#ffb53a 35%,#1d6ce0 100%); } .pa-filters.active { box-shadow:0 8px 32px -4px rgba(15,23,42,.35); }  /* Scroll area (desktop/mode shared) */ .filters-scroll {   flex:1;   min-height:0;          /* wajib agar overflow terbaca dalam flex container */   overflow:auto;   padding-right:6px;   margin-right:-6px;      /* kompensasi scrollbar */   scrollbar-width:thin;   overscroll-behavior:contain; } .filters-scroll::-webkit-scrollbar { width:8px; } .filters-scroll::-webkit-scrollbar-thumb {   background:#cbd5e1;   border-radius:20px;   border:2px solid #f1f5f9; } .filters-scroll::-webkit-scrollbar-thumb:hover { background:#94a3b8; }  /* Heading */ .pa-filters h2 {   margin:0 0 14px;   font-size:20px;   font-weight:700;   letter-spacing:.4px;   line-height:1.15;   background:linear-gradient(90deg,#0f172a,#1d6ce0 60%,#0f172a);   -webkit-background-clip:text;   color:transparent;   background-size:200% 100%;   animation:titleSheen 8s linear infinite; } @keyframes titleSheen {   0%{background-position:0 0}   50%{background-position:100% 0}   100%{background-position:0 0} }  /* Form groups */ .pa-filters .f-group { margin-bottom:18px; position:relative; } .pa-filters label {   display:block;   font-weight:600;   margin:0 0 6px;   font-size:13px;   color:#0f172a;   letter-spacing:.3px; }  /* Inputs / selects */ .pa-filters input[type=text], .pa-filters input[type=number], .pa-filters select {   width:100%;   padding:7px 10px;   border:1px solid #cbd5e1;   border-radius:8px;   font-size:13px;   min-height:34px;   background:#ffffff;   box-sizing:border-box;   color:#0f172a;   transition:border-color .25s, box-shadow .25s, background .25s;   -webkit-appearance:none;   -moz-appearance:none;   appearance:none; } .pa-filters select {   background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230f172a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");   background-repeat:no-repeat;   background-position:right 10px center;   background-size:12px;   padding-right:32px; } .pa-filters input[type=text]:hover, .pa-filters input[type=number]:hover, .pa-filters select:hover { border-color:#94b5ec; } .pa-filters input[type=text]:focus, .pa-filters input[type=number]:focus, .pa-filters select:focus {   outline:none;   border-color:#1d6ce0;   box-shadow:0 0 0 3px rgba(29,108,224,.25);   background:#f8fbff; } .pa-filters .range { display:flex; gap:10px; } .pa-filters .range input { flex:1; } .pa-filters .hint { font-size:11px; color:#64748b; margin-top:6px; }  /* Spec blocks */ .f-specs { margin-top:4px; } .spec-attr {   margin:0 0 14px;   padding:12px 12px 10px;   border:1px solid #e2e8f0;   border-radius:14px;   background:linear-gradient(130deg,#ffffff 0%,#f7faff 85%);   position:relative;   transition:border-color .3s, box-shadow .3s, background .4s; } .spec-attr.collapsed { padding-bottom:8px; } .spec-attr.has-selected {   border-color:#1d6ce0;   box-shadow:0 0 0 2px rgba(29,108,224,.15),0 2px 8px -2px rgba(29,108,224,.35);   background:linear-gradient(135deg,#ffffff 0%,#e9f2ff 100%); } .spec-attr-title {   font-weight:600;   margin:0 0 8px;   font-size:13px;   display:flex;   justify-content:space-between;   align-items:center;   cursor:pointer;   color:#0f172a;   user-select:none; } .spec-attr-title .chevron {   font-size:10px;   transition:transform .25s, opacity .25s;   opacity:.65; } .spec-attr.collapsed .spec-attr-title .chevron {   transform:rotate(-90deg);   opacity:.5; }  /* Spec options */ .spec-attr-options { display:flex; flex-wrap:wrap; gap:6px; } .spec-attr-options label {   display:inline-flex;   align-items:center;   gap:4px;   font-weight:500;   border:1px solid #d4dde7;   padding:6px 9px;   border-radius:30px;   cursor:pointer;   background:#f3f6fa;   font-size:12px;   line-height:1.1;   transition:background .25s, border-color .25s, color .25s, box-shadow .25s;   position:relative; } .spec-attr-options label:hover { background:#e8f1ff; border-color:#b1cff3; } .spec-attr-options input {   margin:0;   position:absolute;   inset:0;   opacity:0;   cursor:pointer; } .spec-attr-options label:has(input:checked) {   background:linear-gradient(135deg,#1d6ce0 0%,#155ab8 100%);   border-color:#1d6ce0;   color:#ffffff;   box-shadow:0 2px 6px -1px rgba(29,108,224,.55); } .spec-attr-options label:has(input:checked)::after {   content:"";   position:absolute;   right:6px;   top:6px;   width:6px;   height:6px;   background:#fff;   border-radius:50%;   box-shadow:0 0 0 4px rgba(255,255,255,.25),0 0 0 7px rgba(29,108,224,.5);   animation:pulseDot 1.9s ease-out infinite; } @keyframes pulseDot {   0%{transform:scale(.8);opacity:.9}   60%{transform:scale(1.4);opacity:.15}   100%{transform:scale(.8);opacity:.9} }  /* Badges */ .pa-filter-badges { margin:0 0 18px; display:flex; flex-wrap:wrap; gap:6px; } .pa-filter-badge {   display:inline-flex;   gap:6px;   align-items:center;   background:linear-gradient(135deg,#eef4ff 0%,#e0edff 100%);   border:1px solid #b4cff3;   padding:5px 10px 5px 12px;   border-radius:22px;   margin:2px 4px 0 0;   font-size:11px;   font-weight:500;   line-height:1;   color:#0f172a;   position:relative;   overflow:hidden; } .pa-filter-badge::before {   content:"";   position:absolute;   inset:0;   background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.35),rgba(255,255,255,0));   transform:translateX(-100%);   animation:badgeSheen 6s linear infinite; } @keyframes badgeSheen {   0%{transform:translateX(-100%)}   55%{transform:translateX(120%)}   100%{transform:translateX(120%)} } .pa-filter-badge a.clear {   text-decoration:none;   color:#c02828;   font-weight:700;   padding:0 3px;   display:inline-flex;   align-items:center;   justify-content:center;   border-radius:50%;   line-height:1;   transition:background .25s, color .25s; } .pa-filter-badge a.clear:hover { background:#ffeded; color:#a40000; } .pa-btn-filter { width: 100%;}  /* =========================================================    ACTIONS (DESKTOP) - STATIC BOTTOM    ========================================================= */ .f-actions {   margin-top:10px;   display:flex;   gap:12px;   flex-wrap:wrap;   padding:16px 0 4px;   border-top:1px solid #e2e8f0;   background:linear-gradient(180deg,rgba(255,255,255,0) 0%,#f1f5f9 70%);   flex-shrink:0; } .f-actions button {   background:linear-gradient(135deg,#1d6ce0 0%,#155ab8 100%);   color:#fff;   border:none;   padding:10px 20px;   border-radius:12px;   cursor:pointer;   font-size:14px;   font-weight:600;   letter-spacing:.3px;   display:inline-flex;   align-items:center;   gap:6px;   box-shadow:0 4px 14px -2px rgba(29,108,224,.45);   transition:transform .25s, box-shadow .3s; } .f-actions button:hover { transform:translateY(-3px); box-shadow:0 8px 26px -4px rgba(29,108,224,.6); } .f-actions button:active { transform:translateY(-1px) scale(.98); box-shadow:0 4px 14px -4px rgba(29,108,224,.55); } .f-actions .reset {   font-size:12px;   text-decoration:none;   color:#d92d2d;   align-self:center;   font-weight:600;   padding:4px 6px;   border-radius:8px;   transition:background .25s, color .25s; } .f-actions .reset:hover { background:#ffe6e6; color:#b80000; text-decoration:underline; } .pa-filters .close-drawer { display: none; }  /* Form wrapper: flex container agar inner .filters-scroll bisa scroll di desktop */ .filter-form {   flex: 1;   min-height: 0;   display: flex;   flex-direction: column;   overflow: hidden; }  /* =========================================================    FILTER TOGGLE (MOBILE TRIGGER)    ========================================================= */ .filter-toggle {   display:none;   margin:0 0 14px;   background:linear-gradient(135deg,#1d6ce0 0%,#155ab8 100%);   color:#fff;   border:none;   padding:11px 18px;   font-size:14px;   font-weight:600;   border-radius:14px;   cursor:pointer;   letter-spacing:.4px;   box-shadow:0 4px 14px -2px rgba(29,108,224,.55);   position:relative;   z-index:100;   transition:box-shadow .3s, transform .25s; } .filter-toggle:hover { box-shadow:0 8px 26px -4px rgba(29,108,224,.6); transform:translateY(-2px); } .filter-toggle:active { transform:translateY(0); box-shadow:0 4px 14px -4px rgba(29,108,224,.55); } .filter-toggle .count-badge {   display:inline-block;   background:linear-gradient(135deg,#f59e0b 0%,#ffb43d 55%,#f59e0b 100%);   color:#1d2b44;   font-size:11px;   font-weight:700;   padding:3px 7px 4px;   border-radius:30px;   margin-left:8px;   box-shadow:0 0 0 2px #ffffff,0 0 0 4px #1d6ce0; }  /* Overlay (mobile) */ .pa-filters-overlay { display:none; }  /* =========================================================    MOBILE DRAWER    ========================================================= */ @media (max-width:768px){   .product-archive.with-filters .pa-layout { flex-direction:column; gap:12px; }   .filter-toggle { display:inline-flex; align-items:center; gap:6px; }    .pa-filters-overlay {     position:fixed;     inset:0;     background:rgba(0,20,45,.55);     z-index:998;     opacity:0;     transition:opacity .35s;     display:block;     pointer-events:none;     backdrop-filter:blur(2px);   }   .pa-filters-overlay.active { opacity:1; pointer-events:auto; }    .pa-filters {     position:fixed;     top:auto;     left:0; right:0; bottom:0;     max-height:92vh;     height:auto;     width:100%;     border-radius:30px 30px 0 0;     border:1px solid #dbe4ef;     padding:26px 22px 0;     z-index:10000; /* di atas bottom-nav (9998) */     transform:translateY(102%);     transition:transform .55s cubic-bezier(.68,-0.35,.25,1);     box-shadow:0 -4px 40px -6px rgba(15,23,42,.45);     overflow:hidden; /* outer hidden, inner scroll */   }   .pa-filters.active { transform:translateY(0); }    /* Drag handle indicator */   .pa-filters::after {     content:"";     display:block;     position:absolute;     top:10px;     left:50%;     transform:translateX(-50%);     width:36px;     height:4px;     background:#cbd5e1;     border-radius:4px;   }   body.filter-open { overflow:hidden; touch-action:none; }    /* Restore mobile-friendly input sizes (prevent iOS zoom on focus) */   .pa-filters input[type=text],   .pa-filters input[type=number],   .pa-filters select {     font-size:16px;     min-height:44px;     padding:10px 12px;     border-radius:10px;   }   .pa-filters select { padding-right:32px; }    .filters-scroll {     flex:1;     overflow:auto;     padding:0 0 120px; /* ruang di atas bar actions */     margin:0;     -webkit-overflow-scrolling:touch;   }    .pa-filters h2 { font-size:19px; margin-bottom:10px; }    .pa-filters .close-drawer {     display: block;     position:absolute;     right:14px; top:12px;     background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%);     color:#fff;     padding:7px 14px;     border:none;     border-radius:10px;     font-size:12px;     font-weight:600;     cursor:pointer;     box-shadow:0 3px 10px -2px rgba(220,38,38,.55);     transition:transform .25s, box-shadow .3s;     z-index: 99;   }   .pa-filters .close-drawer:hover { transform:translateY(-2px); box-shadow:0 6px 18px -4px rgba(220,38,38,.6); }    .spec-attr { border-radius:18px; }   .spec-attr-options label { font-size:11px; padding:5px 9px; }    /* Actions fixed di viewport bawah */   .f-actions {     position:fixed;     left:0; right:0; bottom:0;     margin:0;     border-top:1px solid #d6dee8;     padding:14px 16px calc(16px + env(safe-area-inset-bottom));     background:#ffffffea;     backdrop-filter:blur(6px);     box-shadow:0 -4px 22px -6px rgba(15,23,42,.25);     justify-content:space-between;     z-index:10001; /* di atas pa-filters (10000) dan bottom-nav (9998) */   }    /* Sembunyikan bottom-nav saat filter drawer terbuka */   body.filter-open .bottom-nav {     display: none !important;   }   .f-actions button {     flex:1 1 auto;     justify-content:center;     padding:14px 14px;     font-size:15px;     border-radius:14px;   }   .f-actions .reset {     order:-1;     font-size:12px;     padding:2px 8px;   } }  /* Scrollbar (outer panel desktop only kept for compatibility) */ .pa-filters::-webkit-scrollbar { width:0; } /* disembunyikan karena inner yang scroll */  /* Utilities */ .hidden { display:none !important; } .gradient-text {   background:linear-gradient(90deg,#1d6ce0,#155ab8,#1d6ce0);   -webkit-background-clip:text;   color:transparent;   animation:titleSheen 10s linear infinite; } .glow-focus:focus {   outline:none !important;   box-shadow:0 0 0 3px rgba(29,108,224,.4) !important;   border-color:#1d6ce0 !important; }  /* Simple fade (opsional) */ @keyframes fadeIn {   from { opacity:0; transform:translateY(8px); }   to { opacity:1; transform:translateY(0); } }