
/*
Theme Name: Kay Monareng Creative Portfolio
Theme URI: https://example.com/kay-monareng
Author: Shadoweb / ChatGPT
Description: A premium WordPress portfolio theme for Kabelo Kay Monareng, creative graphic designer and visual communication partner for agencies, startups and businesses.
Version: 9.0.0
License: GPLv2 or later
Text Domain: kaymonareng
*/

:root{
  --km-black:#121214;
  --km-ink:#1e1e22;
  --km-charcoal:#242428;
  --km-white:#ffffff;
  --km-soft:#f5f3ef;
  --km-muted:#737373;
  --km-orange:#ee7526;
  --km-gold:#cba35a;
  --km-line:#e8e2d8;
  --km-shadow:0 24px 70px rgba(0,0,0,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:112px}
body{margin:0;font-family:Arial, Helvetica, sans-serif;color:var(--km-ink);background:var(--km-soft);line-height:1.65}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block;height:auto}
.container{width:min(1180px,92%);margin:0 auto}
.km-header{position:sticky;top:0;z-index:99;background:rgba(18,18,20,.94);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08)}
.admin-bar .km-header{top:32px}
.km-nav{height:86px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.km-brand{display:flex;flex-direction:column;line-height:1}
.km-brand strong{color:#fff;font-size:19px;letter-spacing:.16em;text-transform:uppercase}
.km-brand span{color:var(--km-orange);font-size:11px;letter-spacing:.28em;text-transform:uppercase;margin-top:7px}
.km-menu{display:flex;align-items:center;gap:24px;color:#fff;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.km-menu a{opacity:.86}
.km-menu a:hover,.km-menu a.active-section{opacity:1;color:var(--km-orange)}
.km-cta{background:var(--km-orange);color:#fff!important;padding:13px 20px;border-radius:999px;box-shadow:0 15px 30px rgba(238,117,38,.25);opacity:1!important}
.km-toggle{display:none;background:none;border:0;color:#fff;font-size:28px}

.km-hero{position:relative;min-height:760px;background:#121214;color:#fff;overflow:hidden}
.km-hero:before{content:"";position:absolute;inset:0;background:url('assets/images/hero-collage.jpg') center/cover no-repeat;opacity:.55;filter:saturate(.92)}
.km-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(18,18,20,.96) 0%,rgba(18,18,20,.78) 48%,rgba(18,18,20,.35) 100%)}
.km-hero .container{position:relative;z-index:2;min-height:760px;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:60px}
.km-eyebrow{display:flex;gap:13px;align-items:center;color:var(--km-orange);font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.18em}
.km-eyebrow:before{content:"";width:54px;height:2px;background:var(--km-orange)}
.km-hero h1{font-size:clamp(54px,7vw,96px);line-height:.92;letter-spacing:-.06em;margin:24px 0 22px;text-transform:uppercase}
.km-hero h1 span{color:var(--km-orange)}
.km-hero p{font-size:20px;max-width:660px;color:rgba(255,255,255,.84);margin:0 0 34px}
.km-actions{display:flex;gap:16px;flex-wrap:wrap}
.km-btn{display:inline-flex;align-items:center;gap:10px;background:var(--km-orange);color:#fff!important;border-radius:999px;padding:15px 24px;font-weight:900;text-transform:uppercase;font-size:13px;letter-spacing:.05em;border:0;cursor:pointer}
.km-btn.outline{background:transparent;border:1px solid rgba(255,255,255,.35)}
.km-hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:28px;padding:30px;backdrop-filter:blur(12px);box-shadow:var(--km-shadow)}
.km-hero-card h3{margin:0 0 18px;color:#fff;font-size:21px}
.km-services-list{display:grid;gap:14px}
.km-services-list div{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:13px;color:rgba(255,255,255,.82)}
.km-services-list strong{color:#fff}

.km-section{padding:92px 0;scroll-margin-top:112px}
.km-title{display:flex;justify-content:space-between;gap:30px;align-items:end;margin-bottom:44px}
.km-title .small{color:var(--km-orange);text-transform:uppercase;letter-spacing:.18em;font-weight:900;font-size:13px}
.km-title h2{font-size:clamp(36px,5vw,62px);letter-spacing:-.045em;line-height:1;margin:8px 0 0;color:var(--km-black)}
.km-title p{max-width:540px;color:var(--km-muted);margin:0}
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.about-panel{background:#fff;border-radius:26px;padding:34px;box-shadow:var(--km-shadow)}
.about-panel h3{font-size:28px;margin:0 0 16px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
.stat{background:var(--km-black);color:#fff;border-radius:20px;padding:24px}
.stat strong{font-size:32px;color:var(--km-orange)}
.stat span{display:block;color:rgba(255,255,255,.72);font-size:13px;text-transform:uppercase;letter-spacing:.08em}
.capabilities{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.capability{background:#fff;border:1px solid var(--km-line);border-radius:22px;padding:28px;box-shadow:0 14px 40px rgba(0,0,0,.06)}
.capability .icon{font-size:32px;margin-bottom:16px}
.capability h3{margin:0 0 10px;font-size:21px}
.capability p{margin:0;color:var(--km-muted)}

.portfolio{background:#fff}
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.filter-bar button{border:1px solid var(--km-line);background:#fff;border-radius:999px;padding:10px 16px;font-weight:800;cursor:pointer}
.filter-bar button.active{background:var(--km-black);color:#fff;border-color:var(--km-black)}
.work-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.work-card{position:relative;border-radius:22px;overflow:hidden;background:#eee;min-height:290px;box-shadow:0 18px 48px rgba(0,0,0,.10);cursor:pointer;border:1px solid #eee}
.work-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .35s ease}
.work-card:hover img{transform:scale(1.05)}
.work-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 35%,rgba(0,0,0,.78) 100%);opacity:.82}
.work-info{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:20px;color:#fff}
.work-info span{color:var(--km-orange);font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.1em}
.work-info h3{margin:6px 0 0;font-size:18px;line-height:1.15}
.work-info em{display:block;font-style:normal;font-size:12px;color:rgba(255,255,255,.72);margin-top:8px}
.work-card:nth-child(1),.work-card:nth-child(8),.work-card:nth-child(15),.work-card:nth-child(22),.work-card:nth-child(29){grid-column:span 2;min-height:360px}

.gallery-note{background:var(--km-black);color:#fff;border-radius:26px;padding:30px;margin-bottom:28px;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center}
.gallery-note h3{margin:0 0 8px;color:#fff}
.gallery-note p{margin:0;color:rgba(255,255,255,.72)}
.gallery-note strong{color:var(--km-orange)}

.process{background:var(--km-black);color:#fff}
.process .km-title h2{color:#fff}
.process .km-title p{color:rgba(255,255,255,.66)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.process-card{border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:28px;background:rgba(255,255,255,.04)}
.process-card strong{display:inline-flex;width:44px;height:44px;border-radius:50%;align-items:center;justify-content:center;background:var(--km-orange);margin-bottom:22px}
.process-card h3{margin:0 0 10px}
.process-card p{margin:0;color:rgba(255,255,255,.68)}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:#fff;border-radius:24px;padding:30px;box-shadow:0 18px 45px rgba(0,0,0,.08);border:1px solid var(--km-line)}
.quote p{color:#424242}
.quote strong{color:var(--km-orange)}
.contact{background:linear-gradient(135deg,#151517,#28282c);color:#fff}
.contact .km-title h2{color:#fff}
.contact .km-title p{color:rgba(255,255,255,.7)}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:44px}
.contact-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:28px;padding:32px}
.contact-card h3{margin:0 0 18px}
.contact-card a{display:block;color:#fff;margin:14px 0;font-weight:800}
.contact-form{background:#fff;color:var(--km-ink);border-radius:28px;padding:32px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;border:1px solid #ddd;border-radius:14px;padding:14px 15px;font:inherit;margin-bottom:14px}
.contact-form textarea{min-height:140px}
.contact-form button{border:0}
.km-footer{background:#0b0b0d;color:#fff;text-align:center;padding:26px 0;font-size:14px}
.km-footer span{color:var(--km-orange)}
.back-to-top{position:fixed;right:24px;bottom:24px;width:48px;height:48px;border-radius:50%;background:var(--km-orange);border:0;color:#fff;font-size:22px;z-index:999;box-shadow:0 16px 34px rgba(238,117,38,.3);opacity:0;pointer-events:none;transition:.2s}
.back-to-top.visible{opacity:1;pointer-events:auto}

/* Portfolio modal */
.portfolio-modal{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9999;display:none;align-items:center;justify-content:center;padding:34px}
.portfolio-modal.open{display:flex}
.modal-inner{width:min(1180px,96vw);height:min(92vh,980px);background:#111;border-radius:24px;overflow:hidden;display:grid;grid-template-rows:auto 1fr;box-shadow:0 30px 100px rgba(0,0,0,.55)}
.modal-header{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;background:#19191c;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
.modal-title strong{display:block;font-size:18px}
.modal-title span{color:var(--km-orange);font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.1em}
.modal-actions{display:flex;gap:10px;align-items:center}
.modal-actions a,.modal-actions button{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;border-radius:999px;padding:10px 14px;font-weight:800;cursor:pointer}
.modal-actions button{font-size:20px;width:44px;height:44px;padding:0}
.modal-body{overflow:auto;background:#2a2a2e;display:flex;justify-content:center;align-items:flex-start;padding:28px}
.modal-body img{max-width:100%;height:auto;background:#fff;box-shadow:0 18px 60px rgba(0,0,0,.4)}
@media(max-width:980px){
  html{scroll-padding-top:96px}
  .km-toggle{display:block}
  .km-menu{display:none;position:absolute;top:100%;left:0;right:0;background:#121214;flex-direction:column;align-items:flex-start;padding:24px 5%;box-shadow:0 20px 40px rgba(0,0,0,.25)}
  .km-menu.open{display:flex}
  .km-hero .container,.about-grid,.contact-grid{grid-template-columns:1fr}
  .km-hero-card{display:none}
  .work-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid,.testimonial-grid,.capabilities{grid-template-columns:1fr 1fr}
  .gallery-note{grid-template-columns:1fr}
}
@media(max-width:620px){
  .km-nav{height:76px}
  .km-brand strong{font-size:15px}
  .km-hero,.km-hero .container{min-height:680px}
  .km-hero h1{font-size:48px}
  .km-title{display:block}
  .work-grid,.process-grid,.testimonial-grid,.capabilities,.stats,.form-grid{grid-template-columns:1fr}
  .work-card,.work-card:nth-child(1),.work-card:nth-child(8),.work-card:nth-child(15),.work-card:nth-child(22),.work-card:nth-child(29){grid-column:auto;min-height:300px}
  .portfolio-modal{padding:12px}
  .modal-header{align-items:flex-start}
  .modal-actions a{display:none}
}

/* v3 refinements */
.km-actions .km-btn{margin-bottom:6px}
.contact-card a[href$=".pdf"]{color:var(--km-orange);margin-top:18px}


/* v4 cosmetics: face logo, project enquiries, WhatsApp */
.km-brand-with-logo{
  flex-direction:row !important;
  align-items:center;
  gap:14px;
}
.km-brand-with-logo img{
  width:58px;
  height:58px;
  object-fit:contain;
  display:block;
}
.km-brand-with-logo .brand-text{
  display:flex;
  flex-direction:column;
  line-height:1;
}
.km-brand-with-logo .brand-text small{
  color:var(--km-orange);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-top:7px;
  font-weight:800;
}
.floating-whatsapp{
  position:fixed;
  right:24px;
  bottom:86px;
  width:54px;
  height:54px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#25D366;
  color:#fff !important;
  font-size:27px;
  z-index:998;
  box-shadow:0 16px 34px rgba(37,211,102,.35);
}
@media(max-width:620px){
  .km-brand-with-logo img{width:48px;height:48px}
  .km-brand strong{font-size:13px}
  .km-brand-with-logo .brand-text small{font-size:9px}
  .floating-whatsapp{right:16px;bottom:78px;width:50px;height:50px}
}


/* v5 final: working profile CTA and light content-protection deterrents */
.profile-download-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--km-orange);
  color:#fff !important;
  border-radius:999px;
  padding:13px 20px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.05em;
  box-shadow:0 14px 28px rgba(238,117,38,.24);
  white-space:nowrap;
}
.profile-download-cta:hover{
  transform:translateY(-2px);
}
body.protect-content{
  -webkit-user-select:none;
  -moz-user-select:none;
  -ms-user-select:none;
  user-select:none;
}
body.protect-content input,
body.protect-content textarea,
body.protect-content select{
  -webkit-user-select:auto;
  -moz-user-select:auto;
  -ms-user-select:auto;
  user-select:auto;
}
img{
  -webkit-user-drag:none;
  user-drag:none;
}
.protection-toast{
  position:fixed;
  left:50%;
  bottom:28px;
  transform:translateX(-50%) translateY(12px);
  background:#121214;
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  padding:12px 18px;
  font-weight:800;
  font-size:13px;
  z-index:10000;
  opacity:0;
  pointer-events:none;
  transition:.2s ease;
  box-shadow:0 18px 45px rgba(0,0,0,.28);
}
.protection-toast.visible{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}
@media(max-width:620px){
  .profile-download-cta{width:100%;white-space:normal;text-align:center}
}


/* v6 Production Edition polish */
.site-loader{
  position:fixed;
  inset:0;
  z-index:12000;
  background:#121214;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:opacity .45s ease, visibility .45s ease;
}
.site-loader.loaded{
  opacity:0;
  visibility:hidden;
}
.loader-mark{
  width:118px;
  height:118px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(238,117,38,.48);
  animation:loaderPulse 1.35s ease-in-out infinite;
}
.loader-mark img{
  width:86px;
  height:86px;
  object-fit:contain;
}
@keyframes loaderPulse{
  0%,100%{transform:scale(1);box-shadow:0 0 0 rgba(238,117,38,0)}
  50%{transform:scale(1.06);box-shadow:0 0 45px rgba(238,117,38,.28)}
}
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}
.km-header{
  transition:box-shadow .25s ease, background .25s ease;
}
.km-header.scrolled{
  box-shadow:0 18px 45px rgba(0,0,0,.22);
  background:rgba(18,18,20,.98);
}
.work-card,
.capability,
.process-card,
.quote,
.about-panel{
  will-change:transform;
}
.work-card:hover,
.capability:hover,
.process-card:hover,
.quote:hover{
  transform:translateY(-6px);
}
.capability,
.process-card,
.quote{
  transition:transform .25s ease, box-shadow .25s ease;
}
.modal-body{
  scroll-behavior:smooth;
}
.km-btn,
.km-cta,
.profile-download-cta{
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.km-btn:hover,
.km-cta:hover,
.profile-download-cta:hover{
  transform:translateY(-2px);
}
.km-hero:before{
  transform:scale(1.02);
}
@media(prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
  .reveal{opacity:1;transform:none}
}


/* v7 Signature Edition: premium moving portfolio wall */
.km-hero{
  isolation:isolate;
}
.km-hero:before{
  opacity:.28 !important;
  filter:blur(14px) saturate(.65) brightness(.65) !important;
  transform:scale(1.09) !important;
  animation:portfolioWallDrift 34s linear infinite alternate !important;
}
.km-hero:after{
  background:
    radial-gradient(circle at 75% 46%, rgba(238,117,38,.12), transparent 32%),
    linear-gradient(90deg,rgba(18,18,20,.98) 0%,rgba(18,18,20,.90) 44%,rgba(18,18,20,.72) 100%) !important;
}
.km-hero::selection{
  background:var(--km-orange);
  color:#fff;
}
.km-hero h1 span{
  background:linear-gradient(90deg,#ee7526,#ff9a3c,#ee7526);
  background-size:220% auto;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
  animation:brandGlow 7s ease-in-out infinite;
}
@keyframes portfolioWallDrift{
  0%{background-position:center 48%; transform:scale(1.09) translateY(0)}
  100%{background-position:center 54%; transform:scale(1.12) translateY(-18px)}
}
@keyframes brandGlow{
  0%,100%{background-position:0% center}
  50%{background-position:100% center}
}
.km-hero-card{
  background:rgba(255,255,255,.075) !important;
  border:1px solid rgba(255,255,255,.16) !important;
  box-shadow:0 28px 85px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.12) !important;
}
.km-services-list div{
  position:relative;
  align-items:center;
  transition:background .22s ease, padding-left .22s ease, border-color .22s ease;
  cursor:default;
}
.km-services-list div:after{
  content:"→";
  color:var(--km-orange);
  opacity:0;
  transform:translateX(-8px);
  transition:opacity .22s ease, transform .22s ease;
}
.km-services-list div:hover{
  background:rgba(255,255,255,.045);
  padding-left:12px;
  border-color:rgba(238,117,38,.4);
}
.km-services-list div:hover:after{
  opacity:1;
  transform:translateX(0);
}
.km-services-list div span{
  transition:color .22s ease;
}
.km-services-list div:hover span{
  color:#fff;
}
.km-eyebrow:before{
  box-shadow:0 0 18px rgba(238,117,38,.38);
}
.km-hero p{
  text-shadow:0 1px 12px rgba(0,0,0,.28);
}
@media(prefers-reduced-motion: reduce){
  .km-hero:before,
  .km-hero h1 span{
    animation:none !important;
  }
}


/* v9 CTA hierarchy cleanup */
.km-actions{
  gap:14px;
}
.km-actions .km-btn{
  margin-bottom:0;
}
.gallery-note{
  align-items:center;
}
.gallery-note .profile-download-cta{
  justify-self:end;
}
@media(max-width:980px){
  .gallery-note .profile-download-cta{
    justify-self:start;
  }
}
