/* =========================================================
   JustReused — Homepage visual layer (jr-homepage.css)
   v1.0  2026-06-28
   Adds the OLX-style hero banner + visual section cards
   WITHOUT touching the existing filter columns/livewire.
   All classes are jr-* prefixed to avoid collisions.
   ========================================================= */

/* -- Shared section frame --
   Body uses display:grid which collapses sections to min-content width unless we force stretch.
   width:100% + max-width:1200px + margin:auto gives us a 1200-cap centered section that fills
   the available track width on every screen size. justify-self:stretch is a belt-and-braces add. */
.jr-section{
    box-sizing:border-box;
    width:100%;
    max-width:1200px;
    margin:32px auto;
    padding:0 16px;
    justify-self:stretch;
}
.jr-section-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 18px;letter-spacing:-.01em;}
.jr-section-title-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:0 0 18px;}
.jr-section-title-row .jr-section-title{margin:0;}
.jr-section-link{color:#7e22ce;font-weight:600;font-size:.95rem;text-decoration:none;white-space:nowrap;}
.jr-section-link:hover{text-decoration:underline;color:#6b21a8;}

/* =========================================================
   HERO BANNER
   ========================================================= */
.jr-hero{
    position:relative;
    background:linear-gradient(110deg,#7e22ce 0%,#9333ea 35%,#c026d3 70%,#db2777 100%);
    color:#fff;
    overflow:hidden;
    padding:48px 0 56px;
    width:100%;
    justify-self:stretch;
    /* Explicit min-height: the parent body uses display:grid which combined with overflow:hidden
       on this child resolves min-height:auto -> 0, collapsing the track. Pin a real floor. */
    min-height:380px;
}
.jr-hero::before{
    content:"";
    position:absolute;inset:0;
    background:
        radial-gradient(900px 320px at 18% 0%, rgba(255,255,255,.18), transparent 55%),
        radial-gradient(700px 260px at 100% 100%, rgba(0,0,0,.18), transparent 60%);
    pointer-events:none;
}
.jr-hero-inner{
    position:relative;
    max-width:1200px;margin:0 auto;padding:0 24px;
    display:grid;grid-template-columns:minmax(0,1fr) minmax(0,420px);
    gap:32px;align-items:center;
}
.jr-hero-left{text-align:center;}
.jr-hero-title{
    font-size:clamp(1.6rem,3.4vw,2.6rem);
    font-weight:800;line-height:1.1;letter-spacing:-.02em;
    margin:0 0 14px;
    text-transform:uppercase;
    text-shadow:0 2px 8px rgba(0,0,0,.18);
}
.jr-hero-pill{
    display:inline-block;
    background:#fbbf24;color:#0f172a;
    padding:10px 22px;border-radius:999px;
    font-weight:800;font-size:1.05rem;letter-spacing:.01em;
    margin:6px 0 18px;
    box-shadow:0 6px 18px rgba(251,191,36,.35);
}
.jr-hero-sub{
    font-size:1rem;line-height:1.5;font-weight:500;
    max-width:560px;margin:0 auto 22px;
    color:rgba(255,255,255,.94);
}
.jr-hero-cta{
    display:inline-block;
    background:#fff;color:#7e22ce;
    padding:13px 34px;border-radius:999px;
    font-weight:800;font-size:1rem;text-decoration:none;
    box-shadow:0 10px 24px rgba(0,0,0,.18);
    transition:transform .15s, box-shadow .15s;
}
.jr-hero-cta:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(0,0,0,.22);color:#6b21a8;}

/* Right-side 6 category tiles (2 cols x 3 rows; "Mobile" spans 2 rows) */
.jr-hero-tiles{
    display:grid;
    grid-template-columns:1fr 1fr;
    grid-template-rows:1fr 1fr 1fr;
    gap:12px;
    min-height:280px;
}
.jr-hero-tile{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    background:#f97316;color:#fff;text-decoration:none;
    border-radius:10px;padding:14px 10px;text-align:center;
    font-weight:700;font-size:.92rem;letter-spacing:.01em;
    box-shadow:0 8px 18px rgba(234,88,12,.28);
    transition:transform .15s, box-shadow .15s, background .15s;
    min-height:78px;
}
.jr-hero-tile:hover{transform:translateY(-2px);background:#ea580c;box-shadow:0 12px 22px rgba(234,88,12,.36);color:#fff;}
.jr-hero-tile-icon{font-size:1.5rem;margin-bottom:6px;line-height:1;}
.jr-hero-tile-tall{grid-row:span 2;}

/* Mobile: stack hero */
@media (max-width:900px){
    .jr-hero{padding:32px 0 40px;min-height:auto;}
    .jr-hero-inner{grid-template-columns:1fr;gap:24px;}
    .jr-hero-tiles{min-height:auto;}
    .jr-hero-title{font-size:clamp(1.4rem,5.5vw,1.9rem);}
}
@media (max-width:560px){
    .jr-hero-tiles{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,minmax(64px,auto));}
    .jr-hero-tile-tall{grid-row:auto;}
}

/* =========================================================
   TOP CATEGORIES — visual cards (4 in a row)
   ========================================================= */
.jr-cats-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:16px;
}
.jr-cat-card{
    display:flex;flex-direction:column;
    background:#fff;border:1px solid #e5e7eb;border-radius:12px;
    padding:18px 16px 16px;text-align:center;
    text-decoration:none;color:inherit;
    transition:transform .15s, box-shadow .15s, border-color .15s;
    box-shadow:0 1px 3px rgba(0,0,0,.04);
}
.jr-cat-card:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(0,0,0,.10);border-color:#cbd5e1;color:inherit;}
.jr-cat-thumb{
    width:100%;aspect-ratio:1.6/1;
    background:#f8fafc;border-radius:8px;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;margin-bottom:14px;
}
.jr-cat-thumb img{max-width:80%;max-height:80%;object-fit:contain;}
.jr-cat-name{font-size:1.05rem;font-weight:700;color:#0f172a;margin:0 0 4px;}
.jr-cat-count{font-size:.85rem;color:#64748b;margin:0 0 14px;}
.jr-cat-btn{
    background:#f97316;color:#fff;
    padding:10px 16px;border-radius:8px;
    font-weight:700;font-size:.92rem;
    text-decoration:none;
    transition:background .15s;
    display:block;
}
.jr-cat-card:hover .jr-cat-btn{background:#ea580c;}

/* =========================================================
   PROMO STRIP (purple→pink gradient with CTA text)
   ========================================================= */
.jr-promo-strip{
    background:linear-gradient(110deg,#7e22ce 0%,#9333ea 40%,#c026d3 75%,#db2777 100%);
    padding:34px 16px;text-align:center;color:#fff;
    margin:24px 0;
    width:100%;
    justify-self:stretch;
    box-sizing:border-box;
}
.jr-promo-strip-inner{max-width:1200px;margin:0 auto;}
.jr-promo-strip-title{
    font-size:clamp(1.2rem,2.6vw,1.65rem);
    font-weight:800;letter-spacing:.005em;margin:0 0 10px;
    text-shadow:0 2px 6px rgba(0,0,0,.18);
}
.jr-promo-strip-sub{
    font-size:1rem;line-height:1.5;color:rgba(255,255,255,.92);
    max-width:680px;margin:0 auto 16px;
}
.jr-promo-strip-cta{
    display:inline-block;background:#fbbf24;color:#0f172a;
    padding:11px 26px;border-radius:999px;
    font-weight:800;text-decoration:none;font-size:.95rem;
    box-shadow:0 6px 16px rgba(251,191,36,.4);
    transition:transform .15s;
}
.jr-promo-strip-cta:hover{transform:translateY(-1px);color:#0f172a;}

/* =========================================================
   FEATURED ADS — 3 large cards with green top border
   ========================================================= */
.jr-feat-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:18px;
}
.jr-feat-card{
    background:#fff;border:1px solid #e5e7eb;border-top:3px solid #10b981;border-radius:12px;
    overflow:hidden;text-decoration:none;color:inherit;
    box-shadow:0 1px 3px rgba(0,0,0,.05);
    display:flex;flex-direction:column;
    transition:transform .15s, box-shadow .15s;
}
.jr-feat-card:hover{transform:translateY(-3px);box-shadow:0 18px 32px rgba(0,0,0,.10);color:inherit;}
.jr-feat-thumb{
    width:100%;aspect-ratio:16/10;
    background:#f8fafc;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
}
.jr-feat-thumb img{width:100%;height:100%;object-fit:cover;}
.jr-feat-body{padding:18px;text-align:center;}
.jr-feat-title{font-size:1.05rem;font-weight:700;color:#0f172a;margin:0 0 6px;}
.jr-feat-price{font-size:1.05rem;font-weight:700;color:#0f172a;margin:0 0 4px;}
.jr-feat-loc{font-size:.85rem;color:#64748b;margin:0 0 4px;}
.jr-feat-tag{font-size:.85rem;color:#64748b;font-style:italic;margin:0 0 14px;}
.jr-feat-btn{
    display:block;background:#f97316;color:#fff;
    padding:11px 18px;border-radius:8px;font-weight:700;
    text-decoration:none;
    transition:background .15s;
}
.jr-feat-card:hover .jr-feat-btn{background:#ea580c;}

/* =========================================================
   TOP PICKS — 4 smaller cards
   ========================================================= */
.jr-picks-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:16px;
}
.jr-pick-card{
    background:#fff;border:1px solid #e5e7eb;border-radius:12px;
    overflow:hidden;text-decoration:none;color:inherit;
    box-shadow:0 1px 3px rgba(0,0,0,.05);
    display:flex;flex-direction:column;
    transition:transform .15s, box-shadow .15s;
}
.jr-pick-card:hover{transform:translateY(-3px);box-shadow:0 14px 26px rgba(0,0,0,.10);color:inherit;}
.jr-pick-thumb{
    width:100%;aspect-ratio:16/10;background:#f8fafc;overflow:hidden;
    display:flex;align-items:center;justify-content:center;
}
.jr-pick-thumb img{width:100%;height:100%;object-fit:cover;}
.jr-pick-body{padding:14px;text-align:center;}
.jr-pick-title{font-size:.95rem;font-weight:700;color:#0f172a;margin:0 0 4px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.jr-pick-price{font-size:.95rem;font-weight:700;color:#0f172a;margin:0 0 4px;}
.jr-pick-loc{font-size:.8rem;color:#64748b;margin:0 0 10px;}
.jr-pick-btn{
    display:block;background:#f97316;color:#fff;
    padding:9px 14px;border-radius:8px;font-weight:700;
    text-decoration:none;font-size:.9rem;
    transition:background .15s;
}
.jr-pick-card:hover .jr-pick-btn{background:#ea580c;}

/* =========================================================
   TOP ADS — 2 wide cards with orange left border
   ========================================================= */
.jr-topads-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(360px,1fr));
    gap:18px;
}
.jr-topad-card{
    background:#fff;border:1px solid #e5e7eb;border-left:4px solid #f97316;border-radius:12px;
    overflow:hidden;text-decoration:none;color:inherit;
    box-shadow:0 1px 3px rgba(0,0,0,.05);
    display:flex;align-items:stretch;
    transition:transform .15s, box-shadow .15s;
}
.jr-topad-card:hover{transform:translateY(-3px);box-shadow:0 14px 26px rgba(0,0,0,.10);color:inherit;}
.jr-topad-thumb{flex:0 0 42%;background:#f8fafc;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.jr-topad-thumb img{width:100%;height:100%;object-fit:cover;}
.jr-topad-body{flex:1;padding:18px 18px 16px;text-align:left;display:flex;flex-direction:column;justify-content:center;}
.jr-topad-title{font-size:1.05rem;font-weight:700;color:#0f172a;margin:0 0 4px;}
.jr-topad-price{font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 4px;}
.jr-topad-loc{font-size:.85rem;color:#64748b;margin:0 0 4px;}
.jr-topad-tag{font-size:.82rem;color:#64748b;font-style:italic;margin:0 0 14px;}
.jr-topad-btn{
    align-self:flex-start;
    background:#10b981;color:#fff;
    padding:10px 22px;border-radius:8px;font-weight:700;
    text-decoration:none;font-size:.9rem;
    transition:background .15s;
}
.jr-topad-card:hover .jr-topad-btn{background:#059669;}

/* =========================================================
   POPULAR CATEGORIES — 12 brand-style tiles in a grid
   ========================================================= */
.jr-pop-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(116px,1fr));
    gap:12px;
}
.jr-pop-tile{
    background:#fff;border:1px solid #e5e7eb;border-radius:10px;
    padding:14px 8px 10px;text-align:center;text-decoration:none;color:inherit;
    display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
    min-height:108px;
    transition:transform .15s, box-shadow .15s, border-color .15s;
}
.jr-pop-tile:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(0,0,0,.08);border-color:#cbd5e1;color:inherit;}
.jr-pop-tile-img{
    width:48px;height:48px;border-radius:50%;
    background:#f8fafc;display:flex;align-items:center;justify-content:center;
    overflow:hidden;margin-bottom:8px;
}
.jr-pop-tile-img img{width:80%;height:80%;object-fit:contain;}
.jr-pop-tile-name{font-size:.82rem;color:#334155;font-weight:600;line-height:1.25;}
.jr-pop-more{
    background:#fef3c7;border-color:#fcd34d;
}
.jr-pop-more .jr-pop-tile-img{background:transparent;font-size:1.6rem;color:#b45309;}

/* =========================================================
   Layout helpers
   ========================================================= */
.jr-section-tight{margin:18px auto;}
.jr-section-pull{margin-top:-44px;position:relative;z-index:3;}
@media (max-width:900px){
    .jr-section-pull{margin-top:-28px;}
}

/* Body uses display:grid — make sure none of our sections collapse in grid tracks. */
.jr-section, .jr-promo-strip, .jr-hero{align-self:start;}
