/* P4 Frontend CSS — unified ONE-GATE build
   Base: v1.1.18 admin.css
   Adaptation: R3b p4-front.css + RWD rules
   Built: 2025-09-29
*/

/* ==== [BASE v1.1.18 admin.css] ==== */
:root{ --p4-bg:transparent; --p4-primary:#6C63FF; --p4-accent:#00C9A7; --p4-text:#333; --p4-muted:#666; --p4-card:#fff; --p4-shadow:0 6px 20px rgba(0,0,0,.06); }
.p4-header{display:flex;align-items:center;justify-content:space-between;margin:20px 0 10px;background:var(--p4-card);padding:18px 22px;border-radius:16px;box-shadow:var(--p4-shadow)}
.p4-title{display:flex;gap:14px;align-items:center}
.p4-logo{width:36px;height:36px;border-radius:10px;box-shadow:0 2px 10px rgba(108,99,255,.3)}
.p4-title h1{margin:0;font-size:20px;color:var(--p4-text)}
.p4-title p{margin:4px 0 0;color:var(--p4-muted)}
.p4-upgrade{background:linear-gradient(90deg,var(--p4-primary),var(--p4-accent));color:#fff;padding:10px 14px;border-radius:12px;text-decoration:none;box-shadow:var(--p4-shadow)}
.p4-body{display:flex;gap:18px}
.p4-sidebar{width:220px;background:var(--p4-card);border-radius:16px;box-shadow:var(--p4-shadow);padding:12px;height:fit-content;position:sticky;top:20px}
.p4-catlist{display:flex;flex-direction:column;gap:8px}
.p4-cat{border:none;background:#f3f4f6;color:#111827;padding:10px 12px;border-radius:12px;cursor:pointer;text-align:left;display:flex;gap:10px;align-items:center}
.p4-cat.active{background:var(--p4-primary);color:#fff}
.p4-cat-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:#eef2ff;border-radius:8px}
.p4-cat.active .p4-cat-icon{background:rgba(255,255,255,.25)}
.p4-main{flex:1}
.p4-toolbar{display:flex;gap:12px;align-items:center;margin:10px 0 18px}
#p4-search{flex:1;padding:10px 12px;border-radius:12px;border:1px solid #e5e7eb}
.p4-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.p4-card{background:var(--p4-card);border-radius:18px;padding:18px;box-shadow:var(--p4-shadow);display:flex;flex-direction:column;gap:10px;transition:transform .15s ease, box-shadow .15s ease}
.p4-card:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.08)}
.p4-card h3{margin:0 0 2px;font-size:16px;color:var(--p4-text)}
.p4-card p{margin:0;color:var(--p4-muted)}
.p4-card .p4-actions{margin-top:auto;display:flex;justify-content:flex-end;gap:10px}
.p4-hidden{position:absolute;left:-9999px;opacity:0;height:0}
.p4-cat-badge{background:var(--p4-accent);color:#fff;padding:4px 8px;border-radius:999px;font-size:11px}
.p4-card-top{display:flex;justify-content:space-between;align-items:center;gap:6px}
.p4-fav{border:none;background:transparent;font-size:18px;cursor:pointer}
.p4-toast{position:fixed;right:24px;bottom:24px;background:#111827;color:#fff;padding:10px 14px;border-radius:12px;box-shadow:var(--p4-shadow)}
.p4-copy{background:linear-gradient(90deg,var(--p4-primary),var(--p4-accent)) !important;border:none;color:#fff !important;padding:10px 14px;border-radius:12px;box-shadow:var(--p4-shadow);transition:transform .12s ease, opacity .12s ease}
.p4-copy:hover{opacity:.95;transform:translateY(-1px)}
.p4-loading .p4-card{opacity:.7;pointer-events:none}
.p4-fav{border:none;background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:6px;border-radius:10px}
.p4-fav:hover{background:rgba(0,0,0,.04)}

.p4-copy{font-size:13px !important}

.p4-hdr-search{display:flex;align-items:center;gap:12px}
.p4-hdr-search #p4-search{padding:10px 12px;border-radius:12px;border:1px solid #e5e7eb}
.p4-hdr-count{color:var(--p4-muted)}

.p4-fav svg{fill:#E5E7EB !important; stroke:none !important; transition:transform .12s ease, opacity .12s ease}
.p4-fav:hover svg{fill:#FFD700 !important}
.p4-fav.active svg{fill:#FFD700 !important}

.p4-fav{border:none;background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:6px;border-radius:10px}
.p4-fav:hover svg{fill:#FFD700 !important}
.p4-fav.active svg{fill:#FFD700 !important}
.p4-copy{font-size:13px !important}


/* === v1.1.15 Responsive & non-sticky categories === */
.p4-body{display:flex;gap:24px}
.p4-sidebar{width:260px; position:static !important; top:auto; max-height:none; overflow:visible}
.p4-catlist{display:flex; flex-direction:column; gap:8px}
.p4-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px}
.p4-card{background:#fff;border:1px solid #eef0f3;border-radius:14px;padding:16px;box-shadow:0 1px 2px rgba(0,0,0,.03)}

@media (max-width: 1200px){
  .p4-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width: 1024px){
  .p4-body{flex-direction:column}
  .p4-sidebar{width:100%}
  .p4-catlist{flex-direction:row; flex-wrap:wrap; gap:10px}
}

@media (max-width: 640px){
  .p4-grid{grid-template-columns:1fr}
  .p4-hdr-search{width:100%}
  .p4-hdr-search #p4-search{flex:1; width:100%}
}

/* Buttons & badges */
.p4-cat{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}
.p4-cat.active{background:var(--p4-accent, #00C9A7); color:#fff; border-color:transparent}
.p4-cat-icon{opacity:.9}
.p4-cat-badge{background:#f1f5f9;border-radius:10px;padding:4px 8px;font-size:12px}
.p4-copy{font-size:13px !important}

.p4-title h1{font-weight:700}

/* v1.1.16 */
.p4-cat-badge{background:var(--p4-accent,#00C9A7)!important;color:#fff!important}
@media (max-width: 1024px){
  .p4-header{display:flex;flex-direction:column;gap:12px}
  .p4-actions{width:100%}
  .p4-hdr-search{width:100%}
  .p4-hdr-search #p4-search{width:100%}
}
@media (max-width: 640px){
  .p4-header{display:flex;flex-direction:column;gap:10px}
  .p4-actions{width:100%}
}

/* v1.1.17 */
.p4-cat:hover{background:var(--p4-accent,#00C9A7); color:#fff; border-color:transparent}


/* ==== [R3b p4-front.css overrides] ==== */
/* === P4 Front – Admin-adapted Fit-to-Device === */
*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
#p4-toast,.p4-toast,[data-role="p4-toast"]{position:fixed;left:50%;transform:translateX(-50%);bottom:16px;z-index:999999;padding:10px 14px;border-radius:10px;background:rgba(0,0,0,.86);color:#fff;line-height:1;font-size:14px;pointer-events:none;opacity:0;transition:opacity .2s ease,transform .2s ease}
#p4-toast.is-show,.p4-toast.is-show,[data-role="p4-toast"].is-show{opacity:1}
@media (min-width:1025px){.p4-wrap,.p4-container,.p4-content,.p4-body{max-width:100%;overflow:visible}}
@media (max-width:1024px){
  .p4-wrap,.p4-container,.p4-content,.p4-body{width:100%;max-width:100%;overflow:visible;padding-left:0;padding-right:0}
  .p4-header,.p4-toolbar{padding-left:12px;padding-right:12px}
  .p4-main,.p4-grid,.p4-prompt-list,.p4-list,.p4-cards{padding-left:12px;padding-right:12px}
  .p4-sidebar{width:100% !important;background:transparent !important;box-shadow:none !important;padding:0 !important;border-radius:0 !important}
  .p4-catlist,.p4-categories,.p4-category-list,#p4-cats,[data-role="p4-categories"]{display:flex !important;flex-wrap:nowrap !important;gap:10px !important;overflow-x:auto !important;overflow-y:hidden !important;-webkit-overflow-scrolling:touch !important;padding:0 12px 8px 12px !important;margin:0 !important;scroll-snap-type:x proximity}
  .p4-catlist>*,.p4-categories>*,.p4-category-list>*,#p4-cats>*,[data-role="p4-categories"]>*{flex:0 0 auto !important;scroll-snap-align:start}
  .p4-catlist::-webkit-scrollbar,.p4-categories::-webkit-scrollbar,.p4-category-list::-webkit-scrollbar,#p4-cats::-webkit-scrollbar{display:none !important}
  .p4-grid,.p4-prompt-list,.p4-list,.p4-cards,[data-role="p4-prompt-list"]{display:grid !important;grid-template-columns:1fr !important;grid-auto-rows:auto;gap:14px !important;margin:0 !important;width:100% !important}
  @media (min-width:641px) and (max-width:1024px){.p4-grid,.p4-prompt-list,.p4-list,.p4-cards,[data-role="p4-prompt-list"]{grid-template-columns:1fr 1fr !important}}
  .p4-card,.p4-prompt-card,.p4-item{width:100% !important;max-width:100% !important;min-width:0 !important;overflow:visible !important;margin:0 !important}
  .p4-card *,.p4-prompt-card *,.p4-item *{min-width:0 !important;white-space:normal !important;word-break:break-word !important}
}

/* === P4 precise layout: mobile 1 col, tablet 2 col (fit-to-device) === */
@media (max-width:640px){
  .p4-wrap,.p4-container,.p4-content,.p4-body{max-width:100%!important;width:100%!important;overflow:visible!important;padding-left:0!important;padding-right:0!important}
  .p4-header,.p4-toolbar,.p4-main{padding-left:12px!important;padding-right:12px!important}
  .p4-grid,.p4-prompt-list,.p4-list,.p4-cards,[data-role="p4-prompt-list"]{
    display:grid!important;
    grid-template-columns:1fr!important; /* 1 card per row */
    gap:14px!important;
    width:100%!important;
    padding-left:12px!important; padding-right:12px!important;
    margin:0!important;
  }
  .p4-card,.p4-prompt-card,.p4-item{width:100%!important;max-width:100%!important;min-width:0!important;margin:0!important}
  .p4-card *,.p4-prompt-card *,.p4-item *{min-width:0!important;white-space:normal!important;word-break:break-word!important}
}

@media (min-width:641px) and (max-width:1024px){
  .p4-wrap,.p4-container,.p4-content,.p4-body{max-width:100%!important;width:100%!important;overflow:visible!important;padding-left:0!important;padding-right:0!important}
  .p4-header,.p4-toolbar,.p4-main{padding-left:16px!important;padding-right:16px!important}
  .p4-grid,.p4-prompt-list,.p4-list,.p4-cards,[data-role="p4-prompt-list"]{
    display:grid!important;
    grid-template-columns:1fr 1fr!important; /* 2 cards per row */
    gap:16px!important;
    width:100%!important;
    padding-left:16px!important; padding-right:16px!important;
    margin:0!important;
    box-sizing:border-box!important;
  }
  .p4-card,.p4-prompt-card,.p4-item{width:100%!important;max-width:100%!important;min-width:0!important;margin:0!important}
  .p4-card *,.p4-prompt-card *,.p4-item *{min-width:0!important;white-space:normal!important;word-break:break-word!important}
}
/* Prevent any horizontal scroll from cards/inner elements */
@media (max-width:1024px){
  html,body{overflow-x:hidden!important}
  .p4-card .p4-card-inner,.p4-card .p4-content-inner{max-width:100%!important;overflow:visible!important}
}
/* === END precise layout patch === */


/* Normalize toast width across devices */
#p4-toast,.p4-toast,[data-role="p4-toast"]{
  width:auto !important;
  display:inline-block !important;
  max-width:90vw !important;
  white-space:nowrap !important;
}


#p4-toast,.p4-toast,[data-role="p4-toast"]{left:50% !important;transform:translateX(-50%) !important;bottom:16px !important;}


/* === Toast width same on desktop & mobile === */
#p4-toast,.p4-toast,[data-role="p4-toast"]{
  display:inline-block !important;
  width:max-content !important;
  max-width:90vw !important;
  white-space:nowrap !important;
  left:50% !important;
  transform:translateX(-50%) !important;
  bottom:16px !important;
}


/* === Remove side paddings/margins on .p4-main and .p4-grid (mobile/tablet) === */
@media (max-width:1024px){
  .p4-wrap .p4-main, .p4-wrap .p4-grid,
  .p4-container .p4-main, .p4-container .p4-grid,
  .p4-content .p4-main, .p4-content .p4-grid{
    padding-left:0 !important;
    padding-right:0 !important;
    margin-left:0 !important;
    margin-right:0 !important;
  }
}



/* === Alignment Fixes (v1.1.18 reference) === */
.p4-wrapper{max-width:1120px;margin:0 auto;padding:0 16px;}
.p4-header{max-width:1120px;margin:0 auto;padding:16px;}
.p4-body{margin:0 -0px;} /* keep grid flush with header padding */

.p4-main{padding:0;} /* prevent extra offsets */
.p4-grid{padding:0;margin:0;}

/* Tablet/Mobile edge padding align with header */
@media (max-width:1024px){
  .p4-header{padding:16px;}
  .p4-main{padding:0 16px;}
  .p4-grid{margin:0;}
}

/* Mobile: reorder blocks so "sertakan meta" first, then search+count */
@media (max-width:640px){
  .p4-hdr-search{order:2;width:100%;margin-top:8px;}
  .p4-meta-controls{order:1;width:100%;display:flex;justify-content:center;margin-bottom:4px;}
  .p4-header .p4-title{order:0;}
  .p4-header{display:flex;flex-direction:column;gap:8px;}
}

/* === P4 R3b alignment & mobile order fixes === */
/* Desktop header and cards alignment */
.p4-wrapper{max-width:1120px;margin:0 auto;padding:0 16px;}
.p4-header{max-width:1120px;margin:0 auto;padding:16px 16px 8px;}
/* Ensure action area is flex to allow ordering on mobile */
.p4-actions{display:flex;flex-direction:column;gap:8px}

/* Tablet/Mobile edge padding matches header */
@media (max-width:1024px){
  .p4-main{padding:0 16px;}
  .p4-grid{margin-left:0;margin-right:0}
}

/* Mobile reorder: meta first, then search+count */
@media (max-width:640px){
  .p4-header{display:flex;flex-direction:column;gap:8px}
  .p4-actions{display:flex;flex-direction:column;align-items:stretch}
  .p4-meta-controls{order:1;display:flex;justify-content:center}
  .p4-hdr-search{order:2;width:100%}
}

/* Toast bottom-centered */
#p4-toast{
  position:fixed;left:50%;bottom:24px;transform:translateX(-50%);
  background:rgba(0,0,0,.85);color:#fff;padding:10px 14px;border-radius:8px;
  z-index:99999;display:none;
}



/* === FIX4: container alignment & padding === */
.p4-wrapper{max-width:1120px !important;margin:0 auto !important;padding-left:16px !important;padding-right:16px !important;}
.p4-header{max-width:1120px !important;margin:0 auto !important;padding:16px 16px 8px !important;}
.p4-main{padding:0 !important;}
.p4-grid{margin:0 !important;padding:0 !important;}
.p4-actions{display:flex !important;flex-direction:column !important;gap:8px !important;}

@media (max-width:1024px){
  .p4-main{padding-left:16px !important;padding-right:16px !important;}
  .p4-grid{margin-left:0 !important;margin-right:0 !important;}
}

@media (max-width:640px){
  .p4-header{display:flex !important;flex-direction:column !important;gap:8px !important;}
  .p4-actions{display:flex !important;flex-direction:column !important;align-items:stretch !important;}
  .p4-meta-controls{order:1 !important;display:flex !important;justify-content:center !important;}
  .p4-hdr-search{order:2 !important;width:100% !important;}
}

/* Toast bottom centered */
#p4-toast{
  position:fixed !important;left:50% !important;bottom:24px !important;transform:translateX(-50%) !important;
  background:rgba(0,0,0,.85) !important;color:#fff !important;padding:10px 14px !important;border-radius:8px !important;
  z-index:99999 !important;display:none !important;
}
