.mlpf-page{
  --mlpf-dark:#18171c;
  --mlpf-muted:#6c6b70;
  --mlpf-border:#d9d9db;
  --mlpf-bg:#f0f0f2;
  --mlpf-primary:#5a41bf;
  --mlpf-accent:#ffd23f;
  max-width:1180px;
  margin:0 auto;
  padding:clamp(52px,7vw,92px) 22px;
  color:var(--mlpf-dark);
}
.mlpf-width--narrow{max-width:1040px}.mlpf-width--normal{max-width:1180px}.mlpf-width--wide{max-width:min(1540px,calc(100vw - 64px))}
.mlpf-header{max-width:820px;margin-bottom:34px}.mlpf-kicker{display:flex;align-items:center;gap:12px;margin-bottom:14px;text-transform:uppercase;letter-spacing:.12em;font-weight:850;font-size:.78rem;color:var(--mlpf-primary)}.mlpf-kicker:before{content:"";width:28px;height:2px;background:var(--mlpf-accent)}.mlpf-header h1,.mlpf-single-header h1{font-size:clamp(2.4rem,5vw,4.75rem);line-height:.95;letter-spacing:-.055em;margin:0 0 18px;font-weight:900}.mlpf-header p,.mlpf-single-header p{font-size:1.1rem;line-height:1.8;color:var(--mlpf-muted)}
.mlpf-cats{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 36px}.mlpf-cats a{display:inline-flex;padding:10px 15px;border:1px solid rgba(24,23,28,.14);border-radius:999px;text-decoration:none;color:var(--mlpf-dark);font-weight:750;background:#fff;transition:.18s ease}.mlpf-cats a:hover,.mlpf-cats a.is-active{border-color:var(--mlpf-primary);color:#fff;background:var(--mlpf-primary);box-shadow:0 12px 26px rgba(90,65,191,.18)}
.mlpf-grid{display:grid;grid-template-columns:repeat(var(--mlpf-columns,3),minmax(0,1fr));gap:var(--mlpf-gap,24px)}
.mlpf-featured-wrap{margin-bottom:var(--mlpf-gap,24px)}
.mlpf-card{background:#fff;border:1px solid rgba(24,23,28,.12);border-radius:var(--mlpf-radius,18px);overflow:hidden;box-shadow:0 20px 45px rgba(24,23,28,.065);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;break-inside:avoid;margin-bottom:var(--mlpf-gap,24px)}
.mlpf-grid .mlpf-card,.mlpf-featured-wrap .mlpf-card{margin-bottom:0}.mlpf-card:hover{transform:translateY(-4px);box-shadow:0 28px 65px rgba(24,23,28,.105);border-color:rgba(90,65,191,.25)}
.mlpf-card-img{display:block;aspect-ratio:16/10;background:linear-gradient(135deg,#f2f1f8,#fff);overflow:hidden}.mlpf-ratio-16-9 .mlpf-card-img{aspect-ratio:16/9}.mlpf-ratio-16-10 .mlpf-card-img{aspect-ratio:16/10}.mlpf-ratio-4-3 .mlpf-card-img{aspect-ratio:4/3}.mlpf-ratio-1-1 .mlpf-card-img{aspect-ratio:1/1}.mlpf-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease,filter .4s ease}.mlpf-card:hover img{transform:scale(1.04);filter:saturate(1.04)}
.mlpf-card-body{padding:clamp(20px,2vw,28px)}.mlpf-card h2{font-size:1.32rem;line-height:1.12;margin:0 0 12px;letter-spacing:-.025em;font-weight:900}.mlpf-card h2 a{text-decoration:none;color:var(--mlpf-dark)}.mlpf-card p{color:var(--mlpf-muted);line-height:1.68;margin:0 0 18px}.mlpf-meta{font-size:.74rem;text-transform:uppercase;letter-spacing:.09em;font-weight:850;color:var(--mlpf-primary);margin-bottom:10px}.mlpf-tagsline{display:inline-flex;margin:0 0 14px;padding:5px 9px;border-radius:999px;background:rgba(90,65,191,.08);color:var(--mlpf-primary);font-size:.76rem;font-weight:800}.mlpf-more{display:inline-flex;align-items:center;gap:8px;font-weight:850;color:var(--mlpf-primary);text-decoration:none}.mlpf-more span{transition:transform .18s ease}.mlpf-more:hover span{transform:translateX(4px)}.mlpf-empty{padding:26px;border:1px dashed var(--mlpf-border);border-radius:16px;color:var(--mlpf-muted);background:#fff}.mlpf-img-placeholder{display:flex;align-items:center;justify-content:center;height:100%;min-height:210px;width:100%;background:linear-gradient(135deg,#f0f0f2,#fff);color:var(--mlpf-muted);font-weight:850;border-bottom:1px solid var(--mlpf-border)}
.mlpf-card--featured{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(340px,.82fr);align-items:stretch;border-color:rgba(90,65,191,.20);box-shadow:0 30px 80px rgba(24,23,28,.10)}.mlpf-card--featured .mlpf-card-img{aspect-ratio:auto;min-height:360px;order:2}.mlpf-card--featured .mlpf-card-body{display:flex;flex-direction:column;justify-content:center;padding:clamp(28px,4vw,56px)}.mlpf-card--featured h2{font-size:clamp(2rem,3.5vw,3.8rem);letter-spacing:-.055em;line-height:.96}.mlpf-card--featured p{font-size:1.04rem;max-width:640px}.mlpf-card--featured .mlpf-more{margin-top:8px;align-self:flex-start;padding:12px 16px;border:1px solid rgba(90,65,191,.22);border-radius:999px;background:#fff}
.mlpf-masonry{columns:var(--mlpf-columns,3) 280px;column-gap:var(--mlpf-gap,24px)}.mlpf-masonry-item{break-inside:avoid}.mlpf-archive--masonry .mlpf-card:nth-child(3n+1) .mlpf-card-img{aspect-ratio:4/3}.mlpf-archive--masonry .mlpf-card:nth-child(3n+2) .mlpf-card-img{aspect-ratio:1/1}.mlpf-archive--masonry .mlpf-card:nth-child(3n) .mlpf-card-img{aspect-ratio:16/10}
.mlpf-list{display:grid;gap:14px}.mlpf-list .mlpf-card{display:grid;grid-template-columns:240px minmax(0,1fr);margin-bottom:0}.mlpf-list .mlpf-card-img{aspect-ratio:auto;min-height:180px}.mlpf-list .mlpf-card-body{padding:22px}.mlpf-list .mlpf-card h2{font-size:1.4rem}.mlpf-list .mlpf-tagsline{display:none}
.mlpf-single-header{text-align:center;max-width:860px;margin:0 auto 34px}.mlpf-single-header .mlpf-kicker{justify-content:center}.mlpf-hero-img{margin:0 auto 42px;max-width:1000px;border-radius:22px;overflow:hidden;box-shadow:0 24px 60px rgba(24,23,28,.12)}.mlpf-hero-img img{width:100%;display:block}.mlpf-single-layout{display:grid;grid-template-columns:280px minmax(0,760px);gap:54px;align-items:start}.mlpf-side{position:sticky;top:100px;background:#fff;border:1px solid var(--mlpf-border);border-radius:18px;padding:24px;box-shadow:0 20px 45px rgba(24,23,28,.06)}.mlpf-side div{padding:0 0 16px;margin-bottom:16px;border-bottom:1px solid var(--mlpf-bg)}.mlpf-side span{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--mlpf-muted);font-weight:850;margin-bottom:4px}.mlpf-side strong{display:block;line-height:1.5;word-break:break-word}.mlpf-btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 18px;border-radius:999px;background:var(--mlpf-accent);color:var(--mlpf-dark);text-decoration:none;font-weight:900}.mlpf-content{font-size:1.03rem;line-height:1.85;color:#2a292e}.mlpf-content h2{font-size:2rem;line-height:1.1;margin:2.2em 0 .6em;letter-spacing:-.035em}.mlpf-content img{max-width:100%;border-radius:16px}.mlpf-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:32px}.mlpf-gallery img{width:100%;border-radius:16px}
@media(max-width:1100px){.mlpf-grid{grid-template-columns:repeat(min(var(--mlpf-columns,3),2),minmax(0,1fr))}.mlpf-card--featured{grid-template-columns:1fr}.mlpf-card--featured .mlpf-card-img{order:0;min-height:300px}.mlpf-masonry{columns:2 280px}}
@media(max-width:900px){.mlpf-single-layout{grid-template-columns:1fr}.mlpf-side{position:static;order:2}.mlpf-list .mlpf-card{grid-template-columns:1fr}.mlpf-list .mlpf-card-img{min-height:220px}}
@media(max-width:640px){.mlpf-grid,.mlpf-gallery{grid-template-columns:1fr}.mlpf-masonry{columns:1}.mlpf-page{padding-inline:18px}.mlpf-header h1,.mlpf-single-header h1{font-size:2.5rem}.mlpf-card--featured h2{font-size:2rem}.mlpf-card-body{padding:20px}}


/* ML Portfolio v0.2.3 stronger frontend layout controls */
.mlpf-page{box-sizing:border-box;background:#fff;border:1px solid rgba(24,23,28,.08);border-radius:22px;box-shadow:0 24px 70px rgba(24,23,28,.055)}
.mlpf-page *{box-sizing:border-box}
.mlpf-archive--grid .mlpf-featured-wrap{display:none!important}
.mlpf-archive--grid .mlpf-grid{display:grid!important;grid-template-columns:repeat(var(--mlpf-columns,3),minmax(0,1fr))!important;gap:var(--mlpf-gap,24px)!important}
.mlpf-cols--2 .mlpf-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.mlpf-cols--3 .mlpf-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}.mlpf-cols--4 .mlpf-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important}
.mlpf-card{border-radius:var(--mlpf-radius,18px)!important;border:1px solid rgba(24,23,28,.12)!important;background:#fff!important;overflow:hidden!important}
.mlpf-card-img{border-radius:0!important}.mlpf-card-img img{display:block!important;width:100%!important;height:100%!important;object-fit:cover!important}.mlpf-img-placeholder{min-height:210px!important}
.mlpf-archive--compact .mlpf-list{display:grid!important;gap:16px!important}.mlpf-archive--compact .mlpf-list .mlpf-card{display:grid!important;grid-template-columns:280px minmax(0,1fr)!important;align-items:stretch!important}
.mlpf-archive--masonry .mlpf-masonry{columns:var(--mlpf-columns,3) 260px!important;column-gap:var(--mlpf-gap,24px)!important}.mlpf-archive--masonry .mlpf-card{display:block!important;break-inside:avoid!important}
.mlpf-card--featured{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(340px,.9fr)!important}
@media(max-width:1100px){.mlpf-cols--3 .mlpf-grid,.mlpf-cols--4 .mlpf-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.mlpf-card--featured{grid-template-columns:1fr!important}.mlpf-archive--masonry .mlpf-masonry{columns:2 260px!important}}
@media(max-width:720px){.mlpf-grid,.mlpf-cols--2 .mlpf-grid,.mlpf-cols--3 .mlpf-grid,.mlpf-cols--4 .mlpf-grid{grid-template-columns:1fr!important}.mlpf-archive--compact .mlpf-list .mlpf-card{grid-template-columns:1fr!important}.mlpf-archive--masonry .mlpf-masonry{columns:1!important}.mlpf-page{border-radius:16px;padding:38px 16px!important}}

/* ML Portfolio v0.2.6 — component Options only + featured showcase */
.mlpf-featured-showcase{margin:0 0 42px;padding:26px;border:1px solid rgba(24,23,28,.10);border-radius:calc(var(--mlpf-radius,18px) + 6px);background:linear-gradient(135deg,#fff,rgba(240,240,242,.72));box-shadow:0 22px 60px rgba(24,23,28,.06);overflow:hidden}
.mlpf-featured-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:20px}.mlpf-featured-head p{margin:0;color:var(--mlpf-muted);line-height:1.65;max-width:720px}.mlpf-featured-head .mlpf-kicker{margin-bottom:8px}
.mlpf-featured-track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding:2px 2px 14px;scrollbar-width:thin}.mlpf-featured-slide{flex:0 0 min(78%,920px);scroll-snap-align:start}.mlpf-featured-showcase--grid .mlpf-featured-track{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));overflow:visible;padding-bottom:0}.mlpf-featured-showcase--grid .mlpf-featured-slide{min-width:0;flex:auto}
.mlpf-featured-showcase .mlpf-card--featured{height:100%;grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr)!important}.mlpf-featured-showcase .mlpf-card--featured .mlpf-card-img{min-height:320px}.mlpf-featured-showcase .mlpf-card--featured h2{font-size:clamp(1.8rem,3vw,3.1rem)}
.mlpf-width--wide .mlpf-grid{grid-template-columns:repeat(var(--mlpf-columns,3),minmax(0,1fr))}.mlpf-width--wide{width:min(1540px,calc(100vw - 64px))}
@media(max-width:900px){.mlpf-featured-slide{flex-basis:92%}.mlpf-featured-showcase .mlpf-card--featured{grid-template-columns:1fr!important}.mlpf-featured-showcase .mlpf-card--featured .mlpf-card-img{min-height:240px}.mlpf-width--wide{width:auto}}
@media(max-width:640px){.mlpf-featured-showcase{padding:16px;margin-bottom:30px}.mlpf-featured-slide{flex-basis:100%}.mlpf-featured-head{display:block}}

/* ML Portfolio v0.2.7 — cleaner page width + real featured slider */
.mlpf-page-container--clean{
  background:transparent!important;
  border:0!important;
  border-radius:0!important;
  box-shadow:none!important;
}
.mlpf-page-container--boxed{
  background:#fff!important;
  border:1px solid rgba(24,23,28,.08)!important;
  border-radius:22px!important;
  box-shadow:0 24px 70px rgba(24,23,28,.055)!important;
}
.mlpf-width--full{width:min(1760px,calc(100vw - 48px));max-width:none;}
.mlpf-width--wide{width:min(1500px,calc(100vw - 64px));max-width:none;}
.mlpf-archive{padding-top:clamp(46px,6vw,78px);}
.mlpf-featured-showcase{background:#fff;border:1px solid rgba(24,23,28,.12);box-shadow:0 18px 50px rgba(24,23,28,.07);}
.mlpf-featured-viewport{overflow:hidden;width:100%;}
.mlpf-featured-showcase--slider .mlpf-featured-track{display:flex;gap:0;overflow:visible;scroll-snap-type:none;padding:0;transition:transform .42s cubic-bezier(.2,.8,.2,1);will-change:transform;}
.mlpf-featured-showcase--slider .mlpf-featured-slide{flex:0 0 calc(100% / var(--mlpf-featured-visible,1));padding:0 11px;scroll-snap-align:none;}
.mlpf-featured-showcase--slider .mlpf-featured-slide:first-child{padding-left:0;}
.mlpf-featured-showcase--slider .mlpf-featured-slide:last-child{padding-right:0;}
.mlpf-featured-showcase--slider .mlpf-card--featured{box-shadow:none!important;}
.mlpf-slider-actions{display:flex;gap:10px;align-items:center;flex:0 0 auto;}
.mlpf-slider-btn{width:42px;height:42px;border-radius:999px;border:1px solid rgba(24,23,28,.14);background:#fff;color:var(--mlpf-dark);font-size:28px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s ease;box-shadow:0 10px 22px rgba(24,23,28,.08)}
.mlpf-slider-btn:hover{background:var(--mlpf-primary);border-color:var(--mlpf-primary);color:#fff;transform:translateY(-1px)}
.mlpf-slider-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;background:#fff;color:var(--mlpf-muted)}
.mlpf-slider-dots{display:flex;justify-content:center;gap:8px;margin-top:18px;}
.mlpf-slider-dots button{width:8px;height:8px;border-radius:999px;border:0;background:rgba(24,23,28,.18);padding:0;cursor:pointer;transition:.18s ease;}
.mlpf-slider-dots button.is-active{width:28px;background:var(--mlpf-primary);}
.mlpf-card{transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;}
.mlpf-card:hover{transform:translateY(-3px);box-shadow:0 22px 54px rgba(24,23,28,.11)!important;border-color:rgba(90,65,191,.26)!important;}
@media(max-width:900px){.mlpf-width--wide,.mlpf-width--full{width:auto;max-width:100%;}.mlpf-featured-showcase--slider{--mlpf-featured-visible:1!important}.mlpf-featured-showcase--slider .mlpf-featured-slide{flex-basis:100%;padding:0}.mlpf-slider-actions{margin-top:14px}.mlpf-featured-head{align-items:flex-start;}}


/* ML Portfolio v0.2.9 — SEF router, pagination, lower 16:9 featured slider */
.mlpf-featured-showcase .mlpf-card--featured{
  min-height:0!important;
  grid-template-columns:minmax(0,.94fr) minmax(360px,1.06fr)!important;
}
.mlpf-featured-showcase .mlpf-card--featured .mlpf-card-img{
  aspect-ratio:16/9!important;
  min-height:0!important;
  height:auto!important;
  align-self:center;
  background:#f7f7fa;
}
.mlpf-featured-showcase .mlpf-card--featured .mlpf-card-img img{
  object-fit:contain!important;
  background:#f7f7fa;
}
.mlpf-featured-showcase .mlpf-card--featured .mlpf-card-body{
  padding:clamp(24px,3vw,42px)!important;
}
.mlpf-featured-showcase .mlpf-card--featured h2{
  font-size:clamp(1.75rem,2.7vw,3.15rem)!important;
}
/* ML Portfolio v0.4.0 — custom clean pagination, independent of Joomla icon markup */
.mlpf-pagination{
  display:flex;
  justify-content:center;
  margin:44px 0 0;
}
.mlpf-pagination-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  justify-content:center;
  margin:0;
  padding:0;
  list-style:none;
}
.mlpf-pagination-list > li{
  margin:0;
  padding:0;
}
.mlpf-pagination-list > li > a,
.mlpf-pagination-list > li > span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:42px;
  height:42px;
  padding:0 14px;
  border:1px solid rgba(24,23,28,.12);
  border-radius:14px;
  background:#fff;
  color:var(--mlpf-dark);
  text-decoration:none;
  font-weight:850;
  line-height:1;
  box-shadow:0 8px 20px rgba(24,23,28,.035);
}
.mlpf-pagination-list > li > a:hover,
.mlpf-pagination-list > li.is-active > span{
  background:var(--mlpf-primary);
  border-color:var(--mlpf-primary);
  color:#fff;
  box-shadow:0 12px 26px rgba(90,65,191,.18);
}
.mlpf-pagination-prev > a,
.mlpf-pagination-prev > span,
.mlpf-pagination-next > a,
.mlpf-pagination-next > span{
  gap:8px;
  min-width:0;
  padding-inline:18px;
}
.mlpf-pagination-list > li.is-disabled > span{
  opacity:.42;
  box-shadow:none;
}
.mlpf-pagination-list > li.mlpf-pagination-ellipsis > span{
  border-color:transparent;
  background:transparent;
  box-shadow:none;
  min-width:22px;
  padding-inline:4px;
}
@media(max-width:640px){
  .mlpf-pagination-list{gap:6px;}
  .mlpf-pagination-prev span:not([aria-hidden]),
  .mlpf-pagination-next span:not([aria-hidden]){display:none;}
  .mlpf-pagination-list > li > a,
  .mlpf-pagination-list > li > span{min-width:38px;height:38px;border-radius:12px;padding-inline:12px;}
}
.mlpf-loadmore{display:flex;justify-content:center;margin:42px 0 0;}
.mlpf-loadmore a{display:inline-flex;align-items:center;gap:10px;padding:15px 24px;border-radius:999px;background:var(--mlpf-primary);color:#fff;text-decoration:none;font-weight:900;box-shadow:0 18px 36px rgba(90,65,191,.18);}
.mlpf-loadmore a:hover{transform:translateY(-1px);box-shadow:0 24px 48px rgba(90,65,191,.24);}
@media(max-width:900px){
  .mlpf-featured-showcase .mlpf-card--featured{grid-template-columns:1fr!important;}
  .mlpf-featured-showcase .mlpf-card--featured .mlpf-card-img{order:0;}
}

/* ML Portfolio v0.3.7 — polished single item: custom fields, CTA, related works */
.mlpf-single--polished{padding-top:clamp(46px,5vw,72px)}
.mlpf-single--polished .mlpf-single-header{max-width:1120px;margin-inline:auto;margin-bottom:28px}
.mlpf-back-link{display:inline-flex;align-items:center;gap:8px;margin:0 0 18px;color:var(--mlpf-primary,#5a41bf);font-weight:850;text-decoration:none}
.mlpf-back-link:hover{text-decoration:underline}
.mlpf-single-cover{max-width:1120px;margin:0 auto clamp(30px,4vw,54px)!important;background:#f7f7fa;border-radius:20px;overflow:hidden;box-shadow:0 24px 70px rgba(24,23,28,.10)}
.mlpf-single-cover img{display:block;width:100%;height:auto;object-fit:contain;background:#f7f7fa}
.mlpf-single--polished .mlpf-single-layout{max-width:1120px;margin-inline:auto;grid-template-columns:minmax(260px,330px) minmax(0,1fr);gap:clamp(26px,4vw,54px);align-items:start}
.mlpf-project-side{display:grid;gap:18px}.mlpf-project-box,.mlpf-cta-box{border:1px solid rgba(24,23,28,.10);border-radius:20px;background:#fff;box-shadow:0 18px 48px rgba(24,23,28,.06);padding:24px}.mlpf-project-box h2,.mlpf-cta-box h2{margin:0 0 18px;font-size:1.25rem;line-height:1.2;letter-spacing:-.025em}.mlpf-field-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:13px 0;border-bottom:1px solid rgba(24,23,28,.08)}.mlpf-field-row:first-of-type{padding-top:0}.mlpf-field-row span,.mlpf-field-group>span{display:block;color:var(--mlpf-muted,#6c6b70);font-size:.82rem;font-weight:850;text-transform:uppercase;letter-spacing:.06em}.mlpf-field-row strong{display:block;text-align:right;color:var(--mlpf-dark,#18171c);font-weight:900}.mlpf-field-group{padding:16px 0;border-bottom:1px solid rgba(24,23,28,.08)}.mlpf-pill-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.mlpf-pill-list span{display:inline-flex;align-items:center;min-height:30px;padding:6px 11px;border-radius:999px;background:rgba(90,65,191,.08);border:1px solid rgba(90,65,191,.14);color:var(--mlpf-dark,#18171c);font-size:.86rem;font-weight:800;line-height:1.15}.mlpf-btn--block{display:flex!important;width:100%;justify-content:center;margin-top:18px}.mlpf-cta-box{background:linear-gradient(135deg,var(--mlpf-dark,#18171c),#2a292e);color:#fff;border:0;box-shadow:0 22px 56px rgba(24,23,28,.18)}.mlpf-cta-kicker{margin-bottom:10px;color:#ffd23f;font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem}.mlpf-cta-box h2{color:#fff;margin-bottom:12px}.mlpf-cta-box p{color:rgba(255,255,255,.76);line-height:1.65;margin:0}.mlpf-cta-box .mlpf-btn{background:#ffd23f!important;color:#18171c!important;box-shadow:0 18px 34px rgba(255,210,63,.20)!important}.mlpf-single-content{font-size:1.02rem;line-height:1.8}.mlpf-single-content>p:first-child{margin-top:0}.mlpf-related-section{max-width:1120px;margin:clamp(46px,6vw,82px) auto 0;padding-top:clamp(30px,4vw,46px);border-top:1px solid rgba(24,23,28,.10)}.mlpf-related-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:22px}.mlpf-related-head h2{margin:6px 0 0;font-size:clamp(1.65rem,3vw,2.55rem);line-height:1.08;letter-spacing:-.04em}.mlpf-related-head>a{color:var(--mlpf-primary,#5a41bf);font-weight:900;text-decoration:none;white-space:nowrap}.mlpf-related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.mlpf-related-card{overflow:hidden;border:1px solid rgba(24,23,28,.10);border-radius:20px;background:#fff;box-shadow:0 16px 42px rgba(24,23,28,.06);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.mlpf-related-card:hover{transform:translateY(-3px);box-shadow:0 22px 54px rgba(24,23,28,.11);border-color:rgba(90,65,191,.24)}.mlpf-related-img{display:flex;align-items:center;justify-content:center;aspect-ratio:16/10;background:#f7f7fa;color:var(--mlpf-muted,#6c6b70);font-weight:850;text-decoration:none}.mlpf-related-img img{display:block;width:100%;height:100%;object-fit:cover}.mlpf-related-body{padding:19px}.mlpf-related-meta{margin-bottom:8px;color:var(--mlpf-muted,#6c6b70);font-size:.82rem;font-weight:850;text-transform:uppercase;letter-spacing:.06em}.mlpf-related-body h3{margin:0;font-size:1.12rem;line-height:1.25;letter-spacing:-.025em}.mlpf-related-body h3 a{color:inherit;text-decoration:none}.mlpf-related-body p{margin:10px 0 0;color:var(--mlpf-muted,#6c6b70);line-height:1.6;font-size:.94rem}
@media(max-width:980px){.mlpf-single--polished .mlpf-single-layout{grid-template-columns:1fr}.mlpf-project-side{order:2}.mlpf-related-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mlpf-related-head{align-items:flex-start}}
@media(max-width:640px){.mlpf-single--polished{padding-inline:18px}.mlpf-single-cover{border-radius:16px}.mlpf-project-box,.mlpf-cta-box{padding:20px;border-radius:16px}.mlpf-field-row{display:block}.mlpf-field-row strong{text-align:left;margin-top:5px}.mlpf-related-head{display:block}.mlpf-related-head>a{display:inline-flex;margin-top:12px}.mlpf-related-grid{grid-template-columns:1fr}.mlpf-single--polished .mlpf-single-layout,.mlpf-related-section,.mlpf-single--polished .mlpf-single-header,.mlpf-single-cover{max-width:100%}}

/* ML Portfolio v0.3.9 — cleaner single item layout: content left, project info right */
.mlpf-single--polished{
  background:transparent!important;
  border:0!important;
  border-radius:0!important;
  box-shadow:none!important;
  padding-top:clamp(30px,4vw,54px)!important;
  padding-bottom:clamp(44px,5vw,72px)!important;
}
.mlpf-single--polished .mlpf-single-header,
.mlpf-single--polished .mlpf-single-layout,
.mlpf-single--polished .mlpf-related-section,
.mlpf-single--polished .mlpf-single-cover{
  max-width:1180px;
}
.mlpf-single--polished .mlpf-single-header{
  margin-bottom:22px;
}
.mlpf-single--polished .mlpf-single-header h1{
  max-width:980px;
  margin-left:auto;
  margin-right:auto;
}
.mlpf-single-cover{
  margin-bottom:clamp(26px,3vw,40px)!important;
  border-radius:16px!important;
  box-shadow:0 16px 42px rgba(24,23,28,.08)!important;
}
.mlpf-single--polished .mlpf-single-layout{
  grid-template-columns:minmax(0,1fr) minmax(260px,320px)!important;
  gap:clamp(28px,4vw,46px)!important;
}
.mlpf-project-side{
  position:sticky;
  top:104px;
  display:grid;
  gap:16px;
  align-self:start;
}
.mlpf-project-box,
.mlpf-cta-box{
  border-radius:16px!important;
  padding:22px!important;
}
.mlpf-project-box{
  border:1px solid rgba(24,23,28,.10)!important;
  box-shadow:0 12px 32px rgba(24,23,28,.045)!important;
}
.mlpf-project-box h2,
.mlpf-cta-box h2{
  font-size:1.14rem!important;
}
.mlpf-field-row{
  padding:11px 0!important;
}
.mlpf-field-group{
  padding:13px 0!important;
}
.mlpf-project-box .mlpf-field-row:last-of-type,
.mlpf-project-box .mlpf-field-group:last-of-type{
  border-bottom:0!important;
}
.mlpf-pill-list{
  gap:7px!important;
}
.mlpf-pill-list span{
  min-height:26px!important;
  padding:5px 9px!important;
  font-size:.78rem!important;
}
.mlpf-cta-box{
  background:#18171c!important;
  color:#fff!important;
  border:0!important;
  box-shadow:0 16px 38px rgba(24,23,28,.16)!important;
}
.mlpf-cta-box .mlpf-cta-kicker{
  color:#ffd23f!important;
  border-bottom:1px solid rgba(255,255,255,.18);
  padding-bottom:10px;
  margin-bottom:14px!important;
}
.mlpf-cta-box h2,
.mlpf-cta-box p{
  color:#fff!important;
}
.mlpf-cta-box p{
  color:rgba(255,255,255,.78)!important;
}
.mlpf-cta-box .mlpf-btn{
  background:#ffd23f!important;
  color:#18171c!important;
}
.mlpf-single-content{
  max-width:760px;
  padding-top:2px;
}
.mlpf-related-section{
  margin-top:clamp(42px,5vw,66px)!important;
  padding-top:clamp(26px,3vw,38px)!important;
}
@media(max-width:980px){
  .mlpf-single--polished .mlpf-single-layout{
    grid-template-columns:1fr!important;
  }
  .mlpf-project-side{
    position:static;
    order:2;
  }
  .mlpf-single-content{
    max-width:100%;
  }
}
@media(max-width:640px){
  .mlpf-single--polished{
    padding-inline:18px!important;
  }
  .mlpf-project-box,
  .mlpf-cta-box{
    padding:18px!important;
  }
}

/* ML Portfolio v0.3.9 — configurable single item appearance */
.mlpf-single--polished{
  --mlpf-single-max:1180px;
}
.mlpf-single-width--narrow{--mlpf-single-max:1040px}
.mlpf-single-width--normal{--mlpf-single-max:1180px}
.mlpf-single-width--wide{--mlpf-single-max:min(1360px,calc(100vw - 64px))}
.mlpf-single--polished .mlpf-single-header,
.mlpf-single--polished .mlpf-single-layout,
.mlpf-single--polished .mlpf-related-section,
.mlpf-single--polished .mlpf-single-cover{
  max-width:var(--mlpf-single-max)!important;
}
.mlpf-single-header--left .mlpf-single-header{
  text-align:left!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.mlpf-single-header--left .mlpf-single-header .mlpf-kicker{
  justify-content:flex-start!important;
}
.mlpf-single-header--left .mlpf-single-header h1,
.mlpf-single-header--left .mlpf-single-header p{
  margin-left:0!important;
  margin-right:0!important;
}
.mlpf-single--polished .mlpf-single-layout{
  grid-template-columns:minmax(0,1fr) minmax(260px,var(--mlpf-single-sidebar,320px))!important;
  gap:var(--mlpf-single-gap,42px)!important;
}
.mlpf-single--polished .mlpf-project-box,
.mlpf-single--polished .mlpf-cta-box,
.mlpf-single--polished .mlpf-related-card,
.mlpf-single--polished .mlpf-single-cover{
  border-radius:var(--mlpf-single-radius,16px)!important;
}
.mlpf-single--polished .mlpf-project-box,
.mlpf-single--polished .mlpf-cta-box{
  padding:var(--mlpf-single-box-padding,22px)!important;
}
.mlpf-single-border--none .mlpf-project-box,
.mlpf-single-border--none .mlpf-related-card{
  border:0!important;
}
.mlpf-single-border--subtle .mlpf-project-box,
.mlpf-single-border--subtle .mlpf-related-card{
  border:1px solid rgba(24,23,28,.10)!important;
}
.mlpf-single-border--visible .mlpf-project-box,
.mlpf-single-border--visible .mlpf-related-card{
  border:1px solid rgba(24,23,28,.18)!important;
}
.mlpf-single-shadow--none .mlpf-project-box,
.mlpf-single-shadow--none .mlpf-related-card,
.mlpf-single-shadow--none .mlpf-cta-box{
  box-shadow:none!important;
}
.mlpf-single-shadow--soft .mlpf-project-box,
.mlpf-single-shadow--soft .mlpf-related-card{
  box-shadow:0 12px 32px rgba(24,23,28,.045)!important;
}
.mlpf-single-shadow--medium .mlpf-project-box,
.mlpf-single-shadow--medium .mlpf-related-card{
  box-shadow:0 18px 46px rgba(24,23,28,.075)!important;
}
.mlpf-single-cover-shadow--none .mlpf-single-cover{box-shadow:none!important}
.mlpf-single-cover-shadow--soft .mlpf-single-cover{box-shadow:0 16px 42px rgba(24,23,28,.08)!important}
.mlpf-single-cover-shadow--medium .mlpf-single-cover{box-shadow:0 24px 70px rgba(24,23,28,.13)!important}
.mlpf-single--polished:not(.mlpf-single--sticky-sidebar) .mlpf-project-side{
  position:static!important;
}
@media(max-width:980px){
  .mlpf-single--polished .mlpf-single-layout{
    grid-template-columns:1fr!important;
  }
}

/* ML Portfolio v0.4.1 — cleaner archive layout and category URLs polish */
.mlpf-archive.mlpf-page-container--clean{
  padding-top:clamp(34px,4vw,58px)!important;
  padding-bottom:clamp(44px,5vw,72px)!important;
}
.mlpf-archive .mlpf-header{
  margin-bottom:clamp(24px,3vw,34px)!important;
}
.mlpf-archive .mlpf-header h1{
  font-size:clamp(2.35rem,4.5vw,4.1rem)!important;
  line-height:1!important;
  max-width:920px;
}
.mlpf-archive .mlpf-header p{
  max-width:760px;
  margin-top:0;
}
.mlpf-archive .mlpf-featured-showcase{
  margin-bottom:28px!important;
  padding:18px!important;
  border-radius:18px!important;
  box-shadow:0 14px 38px rgba(24,23,28,.055)!important;
}
.mlpf-archive .mlpf-featured-head{
  margin-bottom:14px!important;
}
.mlpf-archive .mlpf-featured-head p{
  font-size:.96rem!important;
}
.mlpf-archive .mlpf-featured-showcase .mlpf-card--featured{
  box-shadow:none!important;
  border-color:rgba(24,23,28,.08)!important;
}
.mlpf-archive .mlpf-featured-showcase .mlpf-card--featured h2{
  font-size:clamp(1.7rem,2.45vw,2.65rem)!important;
}
.mlpf-archive .mlpf-featured-showcase .mlpf-card--featured .mlpf-card-body{
  padding:clamp(22px,2.6vw,34px)!important;
}
.mlpf-archive .mlpf-featured-showcase .mlpf-card--featured .mlpf-card-img{
  aspect-ratio:16/9!important;
}
.mlpf-archive .mlpf-cats{
  gap:8px!important;
  margin:0 0 30px!important;
}
.mlpf-archive .mlpf-cats a{
  min-height:32px!important;
  padding:7px 12px!important;
  font-size:.84rem!important;
  box-shadow:none!important;
}
.mlpf-archive .mlpf-grid{
  gap:clamp(18px,2.2vw,var(--mlpf-gap,24px))!important;
}
.mlpf-archive .mlpf-card{
  box-shadow:0 12px 30px rgba(24,23,28,.048)!important;
  border-color:rgba(24,23,28,.095)!important;
}
.mlpf-archive .mlpf-card:hover{
  box-shadow:0 20px 46px rgba(24,23,28,.09)!important;
}
.mlpf-archive .mlpf-card-body{
  padding:clamp(17px,1.6vw,23px)!important;
}
.mlpf-archive .mlpf-card h2{
  font-size:clamp(1.08rem,1.3vw,1.24rem)!important;
  line-height:1.18!important;
}
.mlpf-archive .mlpf-card p{
  font-size:.94rem!important;
  line-height:1.58!important;
}
.mlpf-archive .mlpf-tagsline{
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.mlpf-archive .mlpf-more{
  font-size:.92rem!important;
}
@media(max-width:900px){
  .mlpf-archive.mlpf-page-container--clean{padding-inline:18px!important;}
  .mlpf-archive .mlpf-featured-showcase{padding:14px!important;}
}


/* ML Portfolio v0.4.2 — mobile compact cleanup: remove nested-card feel and give content more room */
.mlpf-width--full{max-width:min(1680px,calc(100vw - 32px))!important}

@media(max-width:720px){
  .mlpf-page{
    width:100%!important;
    max-width:100%!important;
    margin-left:auto!important;
    margin-right:auto!important;
    padding:28px 8px 42px!important;
    background:transparent!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
  }

  .mlpf-archive.mlpf-page-container--clean,
  .mlpf-single--polished{
    padding-left:6px!important;
    padding-right:6px!important;
  }

  .mlpf-header,
  .mlpf-single-header{
    margin-bottom:22px!important;
  }

  .mlpf-header h1,
  .mlpf-single-header h1{
    font-size:clamp(2.05rem,10vw,2.65rem)!important;
    line-height:1.02!important;
    letter-spacing:-.045em!important;
  }

  .mlpf-header p,
  .mlpf-single-header p{
    font-size:.98rem!important;
    line-height:1.62!important;
  }

  .mlpf-featured-showcase{
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    margin-bottom:24px!important;
  }

  .mlpf-featured-head{
    padding:0 2px!important;
  }

  .mlpf-featured-showcase .mlpf-card--featured,
  .mlpf-card,
  .mlpf-project-box,
  .mlpf-cta-box,
  .mlpf-related-card{
    border-radius:14px!important;
  }

  .mlpf-card,
  .mlpf-project-box,
  .mlpf-related-card{
    border:1px solid rgba(24,23,28,.08)!important;
    box-shadow:0 10px 26px rgba(24,23,28,.045)!important;
  }

  .mlpf-card-body,
  .mlpf-archive .mlpf-card-body{
    padding:18px 16px!important;
  }

  .mlpf-card h2,
  .mlpf-archive .mlpf-card h2{
    font-size:clamp(1.45rem,7.2vw,2rem)!important;
    line-height:1.08!important;
  }

  .mlpf-card p,
  .mlpf-archive .mlpf-card p{
    font-size:1rem!important;
    line-height:1.62!important;
  }

  .mlpf-cats{
    gap:7px!important;
    margin-bottom:22px!important;
  }

  .mlpf-cats a{
    padding:8px 12px!important;
    min-height:34px!important;
    font-size:.84rem!important;
  }

  .mlpf-single-cover{
    margin-bottom:24px!important;
    border-radius:12px!important;
    box-shadow:none!important;
  }

  .mlpf-single--polished .mlpf-single-layout{
    gap:24px!important;
  }

  .mlpf-single-content{
    font-size:1rem!important;
    line-height:1.7!important;
  }

  .mlpf-project-side{
    gap:14px!important;
  }

  .mlpf-project-box,
  .mlpf-cta-box{
    padding:16px!important;
  }

  .mlpf-field-group,
  .mlpf-field-row{
    padding:10px 0!important;
  }

  .mlpf-pill-list{
    gap:6px!important;
  }

  .mlpf-pill-list span{
    min-height:25px!important;
    padding:5px 8px!important;
    font-size:.76rem!important;
  }

  .mlpf-related-section{
    margin-top:34px!important;
    padding-top:26px!important;
  }

  .mlpf-related-body{
    padding:16px!important;
  }

  .mlpf-pagination{
    margin-top:32px!important;
  }
}

@media(max-width:420px){
  .mlpf-page{
    padding-left:4px!important;
    padding-right:4px!important;
  }

  .mlpf-archive.mlpf-page-container--clean,
  .mlpf-single--polished{
    padding-left:2px!important;
    padding-right:2px!important;
  }

  .mlpf-card-body,
  .mlpf-archive .mlpf-card-body,
  .mlpf-project-box,
  .mlpf-cta-box,
  .mlpf-related-body{
    padding-left:14px!important;
    padding-right:14px!important;
  }
}


/* ML Portfolio v0.4.3 — archive mobile scaling fix */
@media(max-width:768px){
  .mlpf-archive.mlpf-page{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    margin-left:0!important;
    margin-right:0!important;
    padding:24px 0 40px!important;
    overflow-x:hidden!important;
  }

  .mlpf-archive.mlpf-width--wide,
  .mlpf-archive.mlpf-width--full,
  .mlpf-archive.mlpf-width--normal,
  .mlpf-archive.mlpf-width--narrow{
    width:100%!important;
    max-width:100%!important;
  }

  .mlpf-archive .mlpf-header{
    max-width:100%!important;
    margin-bottom:22px!important;
    padding:0 12px!important;
  }

  .mlpf-archive .mlpf-header h1{
    font-size:clamp(2rem,10vw,2.65rem)!important;
    line-height:1.02!important;
    letter-spacing:-.045em!important;
  }

  .mlpf-archive .mlpf-header p{
    font-size:.98rem!important;
    line-height:1.58!important;
  }

  .mlpf-archive .mlpf-featured-showcase{
    width:100%!important;
    max-width:100%!important;
    margin:0 0 24px!important;
    padding:0!important;
    overflow:hidden!important;
  }

  .mlpf-archive .mlpf-featured-head{
    padding:0 12px 12px!important;
    margin-bottom:0!important;
  }

  .mlpf-archive .mlpf-featured-viewport,
  .mlpf-archive .mlpf-featured-track{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }

  .mlpf-archive .mlpf-featured-showcase--slider .mlpf-featured-track{
    display:flex!important;
    gap:0!important;
  }

  .mlpf-archive .mlpf-featured-slide{
    flex:0 0 100%!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    padding:0!important;
  }

  .mlpf-archive .mlpf-card,
  .mlpf-archive .mlpf-card--featured{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }

  .mlpf-archive .mlpf-card--featured{
    display:block!important;
    grid-template-columns:1fr!important;
  }

  .mlpf-archive .mlpf-card-img,
  .mlpf-archive .mlpf-card-img img{
    width:100%!important;
    max-width:100%!important;
  }

  .mlpf-archive .mlpf-card--featured .mlpf-card-img{
    aspect-ratio:16/9!important;
    min-height:0!important;
    order:0!important;
  }

  .mlpf-archive .mlpf-card-body,
  .mlpf-archive .mlpf-card--featured .mlpf-card-body{
    padding:16px 14px!important;
  }

  .mlpf-archive .mlpf-card h2,
  .mlpf-archive .mlpf-card--featured h2{
    font-size:clamp(1.28rem,6.8vw,1.72rem)!important;
    line-height:1.08!important;
    letter-spacing:-.035em!important;
  }

  .mlpf-archive .mlpf-card p,
  .mlpf-archive .mlpf-card--featured p{
    font-size:.96rem!important;
    line-height:1.58!important;
  }

  .mlpf-archive .mlpf-cats{
    padding:0 12px!important;
    gap:7px!important;
  }

  .mlpf-archive .mlpf-cats a{
    max-width:100%!important;
    white-space:normal!important;
  }

  .mlpf-archive .mlpf-grid,
  .mlpf-archive.mlpf-cols--2 .mlpf-grid,
  .mlpf-archive.mlpf-cols--3 .mlpf-grid,
  .mlpf-archive.mlpf-cols--4 .mlpf-grid{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    width:100%!important;
    max-width:100%!important;
    gap:16px!important;
  }

  .mlpf-archive .mlpf-masonry{
    columns:1!important;
  }

  .mlpf-archive .mlpf-list .mlpf-card{
    grid-template-columns:1fr!important;
  }

  .mlpf-archive .mlpf-pagination{
    padding:0 8px!important;
  }

  .mlpf-archive .mlpf-pagination-list{
    max-width:100%!important;
  }
}

@media(max-width:420px){
  .mlpf-archive.mlpf-page{
    padding-left:0!important;
    padding-right:0!important;
  }

  .mlpf-archive .mlpf-card-body,
  .mlpf-archive .mlpf-card--featured .mlpf-card-body{
    padding-left:13px!important;
    padding-right:13px!important;
  }
}


/* ML Portfolio v0.4.4 — hard mobile archive breakout/scaling fix
   The archive view sits inside template/content wrappers on some Joomla layouts.
   On phones it must use the real viewport width and remove nested card framing. */
@media (max-width: 980px){
  html, body{
    overflow-x:hidden;
  }

  .mlpf-archive.mlpf-page{
    box-sizing:border-box!important;
    width:100vw!important;
    max-width:100vw!important;
    min-width:0!important;
    margin-left:calc(50% - 50vw)!important;
    margin-right:calc(50% - 50vw)!important;
    padding:28px 14px 48px!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    background:transparent!important;
    overflow:visible!important;
  }

  .mlpf-archive.mlpf-width--narrow,
  .mlpf-archive.mlpf-width--normal,
  .mlpf-archive.mlpf-width--wide,
  .mlpf-archive.mlpf-width--full{
    max-width:100vw!important;
  }

  .mlpf-archive *,
  .mlpf-archive *::before,
  .mlpf-archive *::after{
    box-sizing:border-box!important;
  }

  .mlpf-archive .mlpf-header,
  .mlpf-archive .mlpf-featured-showcase,
  .mlpf-archive .mlpf-cats,
  .mlpf-archive .mlpf-grid,
  .mlpf-archive .mlpf-list,
  .mlpf-archive .mlpf-masonry,
  .mlpf-archive .mlpf-pagination{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    margin-left:0!important;
    margin-right:0!important;
  }

  .mlpf-archive .mlpf-header{
    padding:0!important;
    margin-bottom:22px!important;
  }

  .mlpf-archive .mlpf-header h1{
    font-size:clamp(2rem,11vw,2.75rem)!important;
    line-height:1.02!important;
    max-width:100%!important;
  }

  .mlpf-archive .mlpf-featured-showcase{
    padding:0!important;
    margin-bottom:24px!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    background:transparent!important;
  }

  .mlpf-archive .mlpf-featured-head{
    padding:0!important;
    margin-bottom:12px!important;
  }

  .mlpf-archive .mlpf-featured-viewport{
    width:100%!important;
    max-width:100%!important;
    overflow:hidden!important;
  }

  .mlpf-archive .mlpf-featured-track{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }

  .mlpf-archive .mlpf-featured-slide{
    flex:0 0 100%!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    padding:0!important;
  }

  .mlpf-archive .mlpf-card,
  .mlpf-archive .mlpf-card--featured{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    margin-left:0!important;
    margin-right:0!important;
    border-radius:16px!important;
  }

  .mlpf-archive .mlpf-card--featured{
    display:block!important;
  }

  .mlpf-archive .mlpf-card-img,
  .mlpf-archive .mlpf-card-img img{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }

  .mlpf-archive .mlpf-card-body,
  .mlpf-archive .mlpf-card--featured .mlpf-card-body{
    padding:18px 16px!important;
  }

  .mlpf-archive .mlpf-grid,
  .mlpf-archive.mlpf-cols--2 .mlpf-grid,
  .mlpf-archive.mlpf-cols--3 .mlpf-grid,
  .mlpf-archive.mlpf-cols--4 .mlpf-grid{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    gap:16px!important;
  }

  .mlpf-archive .mlpf-cats{
    padding:0!important;
    gap:8px!important;
  }

  .mlpf-archive .mlpf-cats a,
  .mlpf-archive .mlpf-tagsline,
  .mlpf-archive .mlpf-more{
    max-width:100%!important;
    white-space:normal!important;
  }
}

@media (max-width: 420px){
  .mlpf-archive.mlpf-page{
    padding-left:10px!important;
    padding-right:10px!important;
  }

  .mlpf-archive .mlpf-card-body,
  .mlpf-archive .mlpf-card--featured .mlpf-card-body{
    padding-left:15px!important;
    padding-right:15px!important;
  }
}


/* ML Portfolio v0.4.5 — mobile archive readability polish
   Keep the viewport fix from v0.4.4, but return controlled breathing room and calm typography. */
@media (max-width: 980px){
  .mlpf-archive.mlpf-page{
    padding:26px 16px 46px!important;
  }

  .mlpf-archive .mlpf-header,
  .mlpf-archive .mlpf-featured-head,
  .mlpf-archive .mlpf-cats,
  .mlpf-archive .mlpf-pagination{
    padding-left:2px!important;
    padding-right:2px!important;
  }

  .mlpf-archive .mlpf-kicker{
    font-size:.66rem!important;
    letter-spacing:.11em!important;
    margin-bottom:9px!important;
  }

  .mlpf-archive .mlpf-header h1{
    font-size:clamp(1.72rem,8.4vw,2.28rem)!important;
    line-height:1.04!important;
    letter-spacing:-.04em!important;
    margin-bottom:10px!important;
  }

  .mlpf-archive .mlpf-header p{
    font-size:.92rem!important;
    line-height:1.55!important;
    margin-top:0!important;
  }

  .mlpf-archive .mlpf-featured-showcase{
    margin-bottom:22px!important;
  }

  .mlpf-archive .mlpf-card,
  .mlpf-archive .mlpf-card--featured{
    border-radius:14px!important;
    box-shadow:0 14px 34px rgba(24,23,28,.055)!important;
  }

  .mlpf-archive .mlpf-card-body,
  .mlpf-archive .mlpf-card--featured .mlpf-card-body{
    padding:17px 16px 18px!important;
  }

  .mlpf-archive .mlpf-card h2,
  .mlpf-archive .mlpf-card--featured h2{
    font-size:clamp(1.16rem,5.9vw,1.46rem)!important;
    line-height:1.12!important;
    letter-spacing:-.028em!important;
    margin-bottom:10px!important;
  }

  .mlpf-archive .mlpf-card p,
  .mlpf-archive .mlpf-card--featured p{
    font-size:.91rem!important;
    line-height:1.58!important;
    margin-bottom:14px!important;
  }

  .mlpf-archive .mlpf-meta{
    font-size:.68rem!important;
    margin-bottom:8px!important;
  }

  .mlpf-archive .mlpf-tagsline{
    font-size:.70rem!important;
    padding:5px 8px!important;
    margin-bottom:12px!important;
  }

  .mlpf-archive .mlpf-more{
    font-size:.86rem!important;
  }

  .mlpf-archive .mlpf-cats{
    gap:7px!important;
    margin-bottom:20px!important;
  }

  .mlpf-archive .mlpf-cats a{
    padding:7px 10px!important;
    font-size:.78rem!important;
    line-height:1.2!important;
  }

  .mlpf-archive .mlpf-grid,
  .mlpf-archive.mlpf-cols--2 .mlpf-grid,
  .mlpf-archive.mlpf-cols--3 .mlpf-grid,
  .mlpf-archive.mlpf-cols--4 .mlpf-grid{
    gap:15px!important;
  }
}

@media (max-width: 420px){
  .mlpf-archive.mlpf-page{
    padding-left:14px!important;
    padding-right:14px!important;
  }

  .mlpf-archive .mlpf-header h1{
    font-size:clamp(1.62rem,8vw,2.05rem)!important;
  }

  .mlpf-archive .mlpf-card h2,
  .mlpf-archive .mlpf-card--featured h2{
    font-size:clamp(1.08rem,5.7vw,1.34rem)!important;
  }

  .mlpf-archive .mlpf-card-body,
  .mlpf-archive .mlpf-card--featured .mlpf-card-body{
    padding-left:15px!important;
    padding-right:15px!important;
  }
}

/* ML Portfolio v0.4.7 — linked category/tag pills in project summary */
.mlpf-pill-list--links a{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:5px 9px;
  border-radius:999px;
  background:rgba(90,65,191,.08);
  border:1px solid rgba(90,65,191,.14);
  color:var(--mlpf-dark,#18171c);
  font-size:.78rem;
  font-weight:800;
  line-height:1.15;
  text-decoration:none;
  transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease;
}
.mlpf-pill-list--links a:hover,
.mlpf-pill-list--links a:focus-visible{
  background:var(--mlpf-primary,#5a41bf);
  border-color:var(--mlpf-primary,#5a41bf);
  color:#fff;
  transform:translateY(-1px);
}
@media (max-width: 767px){
  .mlpf-pill-list--links a{
    min-height:25px;
    padding:5px 8px;
    font-size:.76rem;
  }
}

/* v0.4.8 category archive description */
.mlpf-category-description {
  max-width: 920px;
  margin: 12px auto 0;
  color: var(--ml-color-muted, #6c6b70);
  font-size: 1.05rem;
  line-height: 1.75;
}
.mlpf-header .mlpf-category-description p {
  margin: 0 0 .75rem;
}
.mlpf-header .mlpf-category-description p:last-child {
  margin-bottom: 0;
}
.mlpf-single .mlpf-pill-list--links a,
.mlpf-pill-list--links a {
  text-decoration: none;
}

/* Technology badge in single portfolio sidebar */
.mlpf-tech-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 34px;
  padding: 5px 12px 5px 6px;
  border: 1px solid rgba(90, 65, 191, .18);
  border-radius: 999px;
  background: rgba(248, 247, 255, .95);
  color: var(--ml-dark, #18171c);
  font-weight: 800;
  font-size: 13px;
  line-height: 1;
}
.mlpf-tech-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 26px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--ml-primary, #5a41bf);
  color: #fff;
  font-size: 10px;
  letter-spacing: -.02em;
  font-weight: 900;
}
.mlpf-tech-badge--wordpress .mlpf-tech-icon { background: #21759b; }
.mlpf-tech-badge--joomla .mlpf-tech-icon { background: #5091cd; }
.mlpf-tech-badge--woocommerce .mlpf-tech-icon { background: #7f54b3; }
.mlpf-tech-badge--shopify .mlpf-tech-icon { background: #95bf47; color: #111; }
.mlpf-tech-badge--custom-php .mlpf-tech-icon { background: #777bb4; }
.mlpf-tech-badge--html-css .mlpf-tech-icon { background: #e44d26; }
.mlpf-field-group--technology .mlpf-tech-badge { margin-top: 8px; }


/* Client reviews on single portfolio item */
.mlpf-client-reviews-section {
  margin-top: clamp(34px, 5vw, 70px);
  padding-top: clamp(24px, 4vw, 44px);
  border-top: 1px solid rgba(24, 23, 28, .10);
}

.mlpf-client-reviews-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.mlpf-client-reviews-head h2 {
  margin: 4px 0 0;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1.08;
  letter-spacing: -.03em;
}

.mlpf-client-reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
  gap: 16px;
}

.mlpf-client-review-card {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  padding: clamp(20px, 3vw, 30px);
  border: 1px solid rgba(24, 23, 28, .10);
  border-radius: calc(var(--mlpf-single-radius, 16px) + 6px);
  background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,247,255,.86));
  box-shadow: 0 18px 45px rgba(24, 23, 28, .08);
}

.mlpf-client-review-mark {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: #5a41bf;
  color: #fff;
  font-size: 32px;
  line-height: 1;
  font-weight: 800;
  font-family: Georgia, serif;
}

.mlpf-client-review-body {
  min-width: 0;
}

.mlpf-client-review-top {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  color: rgba(24, 23, 28, .58);
  font-size: 13px;
  font-weight: 700;
}

.mlpf-client-review-stars {
  display: inline-flex;
  gap: 2px;
  color: rgba(24, 23, 28, .18);
  letter-spacing: .02em;
}

.mlpf-client-review-stars .is-filled {
  color: #ffb34d;
}

.mlpf-client-review-card blockquote {
  margin: 0;
  color: #252333;
  font-size: clamp(17px, 2vw, 22px);
  line-height: 1.52;
  font-weight: 650;
  letter-spacing: -.02em;
}

.mlpf-client-review-author {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
}

.mlpf-client-review-author img,
.mlpf-client-review-avatar {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  object-fit: cover;
  flex: 0 0 auto;
}

.mlpf-client-review-avatar {
  display: grid;
  place-items: center;
  background: rgba(90, 65, 191, .10);
  color: #5a41bf;
  font-weight: 800;
}

.mlpf-client-review-author strong,
.mlpf-client-review-author small {
  display: block;
}

.mlpf-client-review-author strong {
  color: #18171c;
  font-size: 15px;
  line-height: 1.2;
}

.mlpf-client-review-author small {
  margin-top: 2px;
  color: rgba(24, 23, 28, .58);
  font-size: 13px;
}

@media (max-width: 640px) {
  .mlpf-client-review-card {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 20px;
  }

  .mlpf-client-review-mark {
    width: 36px;
    height: 36px;
    font-size: 28px;
  }
}

/* v0.5.16 clean project status badge */
.mlpf-project-status{display:inline-flex!important;align-items:center;justify-content:center;min-height:30px;padding:6px 11px;border-radius:999px;font-size:.86rem;font-weight:900;line-height:1.15;text-align:center!important;background:rgba(90,65,191,.08);border:1px solid rgba(90,65,191,.16);color:var(--mlpf-primary,#5a41bf)}
.mlpf-project-status.is-active{background:rgba(45,156,82,.10);border-color:rgba(45,156,82,.20);color:#2d7d46}
.mlpf-project-status.is-archive,.mlpf-project-status.is-offline,.mlpf-project-status.is-redesigned{background:rgba(255,210,63,.20);border-color:rgba(255,210,63,.42);color:#7a5600}

/* v0.5.26 - Portfolio placeholder images */
.mlpf-placeholder-image{background:#f7f6fb!important;object-fit:cover!important;}
.mlpf-single-cover--placeholder{background:linear-gradient(135deg,#f7f6fb,#ffffff)!important;}
.mlpf-single-cover--placeholder img{object-fit:cover!important;width:100%!important;}
