/* 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;
  }
}

/* =============================================
   FIX PACK — 2025-09-29 — Seven-point adjustments
   ============================================= */

/* 1) Desktop p4-header width 1120px and margin-bottom 20px */
@media (min-width:1025px){
  .p4-header{
    max-width:1120px !important;
    margin:0 auto 20px !important;
  }
}

/* 2) Desktop: copy button align right, no full width */
@media (min-width:1025px){
  .p4-card .p4-actions,
  .p4-actions .p4-copy-wrap{
    display:flex !important;
    justify-content:flex-end !important;
    align-items:center !important;
    gap:8px !important;
  }
  .p4-card .p4-copy,
  .p4-card .p4-copy-btn{
    width:auto !important;
    display:inline-flex !important;
  }
}

/* 3) Tablet & Mobile: side paddings match header */
@media (max-width:767px){
  .p4-main, .p4-grid{ padding-left:16px !important; padding-right:16px !important; }
}
@media (min-width:768px) and (max-width:1024px){
  .p4-main, .p4-grid{ padding-left:24px !important; padding-right:24px !important; }
}

/* 4) Mobile: place search+count under "sertakan meta saat copy" */
@media (max-width:767px){
  .p4-hdr-search{ display:flex !important; flex-direction:column !important; gap:8px !important; }
  .p4-hdr-search .p4-meta-controls{ order:1 !important; align-self:center !important; }
  #p4-search{ order:2 !important; width:100% !important; }
  .p4-hdr-count{ order:3 !important; align-self:flex-start !important; }
}

/* 5) Desktop toast visibility & 6) Bottom-centered toast (all devices) */
#p4-toast,.p4-toast,[data-role="p4-toast"]{
  position:fixed !important;
  display:none; /* JS shows it */
  left:50% !important;
  transform:translateX(-50%) !important;
  right:auto !important;
  bottom:16px !important;
  z-index:9999 !important;
  width:max-content !important;
  max-width:90vw !important;
  white-space:nowrap !important;
  pointer-events:none !important;
}
/* visible state (if used) */
#p4-toast.is-visible,.p4-toast.is-visible,[data-role="p4-toast"].is-visible{ display:inline-block !important; }

/* 7) Ensure logo image defaults to existing path when empty (handled in PHP constant) */
/* No CSS needed */


/* FIX3-1 (Mobile): align search & count in one row under meta */
@media (max-width:767px){
  .p4-hdr-search{
    display:grid !important;
    grid-template-columns: 1fr auto !important;
    grid-template-areas:
      "meta  meta"
      "search count" !important;
    gap:8px !important;
  }
  .p4-hdr-search .p4-meta-controls{ grid-area: meta !important; justify-self:center !important; }
  #p4-search{ grid-area: search !important; width:100% !important; }
  .p4-hdr-count{ grid-area: count !important; align-self:center !important; }
}


/* FIX3-2/3: remove side paddings on mobile & tablet for .p4-grid and .p4-main */
@media (max-width:767px){
  .p4-main, .p4-grid{ padding-left:0 !important; padding-right:0 !important; }
}
@media (min-width:768px) and (max-width:1024px){
  .p4-main, .p4-grid{ padding-left:0 !important; padding-right:0 !important; }
}
