/* Prakala Legal — Theme CSS (pixel-port of the Lovable build)
   All visual styling lives here. CSS custom-properties are injected
   by inc/enqueue.php → prakala_dynamic_css() from the Customizer. */

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--pk-bg);
  color:var(--pk-text);
  font-family:var(--pk-font-body);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-height:1.6;
}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
::selection{background:color-mix(in srgb,var(--pk-primary) 40%,transparent);color:#000}

/* Headings */
h1,h2,h3,h4,h5,h6,.pk-h1,.pk-h2,.pk-h3{font-family:var(--pk-font-heading);letter-spacing:-.02em;line-height:1.05;margin:0;font-weight:600}
.pk-h1{font-size:clamp(2.75rem,8vw,7rem)}
.pk-h2{font-size:clamp(2rem,4.5vw,3.5rem)}
.pk-h3{font-size:clamp(1.2rem,1.6vw,1.6rem);line-height:1.25}
.pk-lead{font-size:clamp(1rem,1.2vw,1.18rem);color:var(--pk-muted);max-width:42rem;margin:24px auto 0;line-height:1.7}
.pk-body{color:var(--pk-muted);font-size:1rem;line-height:1.7}
.pk-eyebrow{text-transform:uppercase;letter-spacing:.3em;font-size:.72rem;color:var(--pk-primary);font-weight:500;display:inline-block}
.pk-gradient-text{background:linear-gradient(90deg,var(--pk-primary),#bff060,var(--pk-primary));-webkit-background-clip:text;background-clip:text;color:transparent}
.pk-index{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:color-mix(in srgb,var(--pk-primary) 80%,transparent);font-weight:500}
.pk-center{text-align:center}
.pk-narrow{max-width:780px;margin-left:auto;margin-right:auto}

/* Layout */
.pk-container{max-width:1180px;margin:0 auto;padding:0 24px;position:relative;z-index:2}
.pk-section{padding:128px 0;position:relative}
.pk-main{position:relative;z-index:1;min-height:60vh}
.pk-grid-2{display:grid;grid-template-columns:1fr;gap:64px;align-items:center}
@media(min-width:900px){.pk-grid-2{grid-template-columns:1fr 1fr;gap:80px}}
.pk-cards-grid{display:grid;gap:24px;grid-template-columns:1fr}
.pk-cards-3{grid-template-columns:1fr}
.pk-cards-4{grid-template-columns:1fr}
@media(min-width:700px){.pk-cards-3,.pk-cards-4{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.pk-cards-3{grid-template-columns:repeat(3,1fr)}.pk-cards-4{grid-template-columns:repeat(4,1fr)}}

/* Buttons */
.pk-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:999px;font-weight:600;letter-spacing:.01em;transition:transform .3s,box-shadow .3s,background .3s,border-color .3s;line-height:1}
.pk-btn-primary{background:linear-gradient(135deg,var(--pk-primary),#bff060);color:#0a120e;box-shadow:0 0 0 rgba(0,0,0,0)}
.pk-btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 50px -10px color-mix(in srgb,var(--pk-primary) 60%,transparent)}
.pk-btn-ghost{background:transparent;color:#fff;border:1px solid color-mix(in srgb,var(--pk-primary) 50%,transparent);padding:13px 27px}
.pk-btn-ghost:hover{border-color:var(--pk-primary);background:color-mix(in srgb,var(--pk-primary) 8%,transparent)}

/* Cards */
.pk-card{
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.012));
  border:1px solid var(--pk-border);
  backdrop-filter:blur(10px);
  border-radius:var(--pk-radius);
  padding:32px;
  position:relative;
  transition:transform .4s,border-color .4s,background .4s,box-shadow .4s,color .4s;
}
.pk-glass{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.012));border:1px solid var(--pk-border);backdrop-filter:blur(10px);border-radius:var(--pk-radius)}

/* Header */
.pk-header{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .35s,backdrop-filter .35s,border-color .35s;background:transparent;border-bottom:1px solid transparent}
.pk-header.is-scrolled{background:rgba(8,9,8,.82);backdrop-filter:blur(18px);border-bottom-color:rgba(255,255,255,.06)}
.pk-header-inner{max-width:1280px;margin:0 auto;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.pk-logo{display:inline-flex;align-items:center;gap:12px;font-family:var(--pk-font-heading);font-size:1.05rem;color:#fff;letter-spacing:-.01em}
.pk-logo strong{color:var(--pk-primary);font-weight:600}
.pk-logo-mark{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--pk-primary),#9ae040);color:#0a120e;font-weight:700}
.pk-nav{display:none}
.pk-nav ul{list-style:none;display:flex;gap:32px;padding:0;margin:0}
.pk-nav a{font-size:.92rem;color:rgba(255,255,255,.85);transition:color .25s}
.pk-nav a:hover{color:var(--pk-primary)}
.pk-header-cta{display:none;padding:10px 18px;border-radius:999px;background:linear-gradient(135deg,var(--pk-primary),#bff060);color:#0a120e;font-weight:600;font-size:.88rem}
.pk-menu-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:38px;height:38px;align-items:center;border-radius:8px}
.pk-menu-toggle span{width:22px;height:2px;background:#fff;transition:transform .3s}
@media(min-width:960px){
  .pk-nav{display:block}
  .pk-header-cta{display:inline-flex}
  .pk-menu-toggle{display:none}
}
body.pk-menu-open .pk-nav{display:block;position:fixed;inset:74px 0 0 0;background:rgba(8,9,8,.97);backdrop-filter:blur(20px);padding:40px 24px;z-index:55}
body.pk-menu-open .pk-nav ul{flex-direction:column;gap:24px}

/* Hero */
.pk-hero{min-height:100svh;display:flex;align-items:center;padding:160px 0 96px}
.pk-hero-inner{text-align:center;max-width:980px;margin:0 auto;padding:0 24px}
.pk-h1{margin-top:24px}
.pk-hero-actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:40px}

/* Stats */
.pk-stats-grid{display:grid;grid-template-columns:1fr;gap:16px;max-width:880px;margin:64px auto 0}
@media(min-width:700px){.pk-stats-grid{grid-template-columns:repeat(3,1fr);gap:24px}}
.pk-stat{padding:28px;text-align:center}
.pk-stat-num{font-family:var(--pk-font-heading);font-size:clamp(1.8rem,3.2vw,2.4rem);color:var(--pk-primary);font-weight:600}
.pk-stat-suffix{margin-top:8px;font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--pk-muted)}

/* Why-choose cards: green glow hover */
.pk-why-card{height:100%}
.pk-why-num{font-family:var(--pk-font-heading);color:var(--pk-primary);font-size:3rem;line-height:1}
.pk-why-card:hover{background:linear-gradient(135deg,var(--pk-primary),#bff060);border-color:var(--pk-primary);color:#0a120e;transform:translateY(-4px);box-shadow:0 0 60px color-mix(in srgb,var(--pk-primary) 50%,transparent)}
.pk-why-card:hover h3,.pk-why-card:hover p,.pk-why-card:hover .pk-h3,.pk-why-card:hover .pk-body,.pk-why-card:hover .pk-why-num,.pk-why-card:hover .pk-stat-num,.pk-why-card:hover .pk-stat-suffix{color:#0a120e!important}

/* Marquee */
.pk-marquee{padding:40px 0;border-top:1px solid var(--pk-border);border-bottom:1px solid var(--pk-border);background:rgba(0,0,0,.3);overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.pk-marquee-track{display:inline-flex;align-items:center;gap:56px;white-space:nowrap;animation:pk-marquee 30s linear infinite;padding-right:56px}
.pk-marquee-item{display:inline-flex;align-items:center;gap:14px;font-family:var(--pk-font-heading);font-size:clamp(1.4rem,3vw,2.4rem);color:rgba(255,255,255,.85)}
.pk-marquee-item::after{content:"";width:10px;height:10px;border-radius:999px;background:var(--pk-primary);box-shadow:0 0 14px color-mix(in srgb,var(--pk-primary) 80%,transparent);margin-left:40px}
.pk-marquee-item .pk-icon{width:22px;height:22px;color:var(--pk-primary)}
@keyframes pk-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* About art (image) */
.pk-about-art{
  position:relative;aspect-ratio:4/5;border-radius:var(--pk-radius);overflow:hidden;
  border:1px solid var(--pk-border);
  background:
    radial-gradient(circle at 50% 30%,color-mix(in srgb,var(--pk-primary) 18%,transparent),transparent 70%),
    linear-gradient(180deg,#101410,#070807);
  display:grid;place-items:center;
}
.pk-about-art::before{
  content:"";position:absolute;inset:0;
  background-image:url('../img/lady-justice.png');
  background-size:contain;background-repeat:no-repeat;background-position:center;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.7));
  transition:transform .4s ease-out;
}
.pk-about-art:hover::before{transform:scale(1.03)}
.pk-art-caption{position:absolute;left:24px;right:24px;bottom:24px;z-index:2}
.pk-art-caption .pk-h3{color:#fff;margin-top:8px}

/* Practice cards (stacking) */
.pk-practice-stack{margin-top:64px;display:flex;flex-direction:column;gap:24px;max-width:780px;margin-left:auto;margin-right:auto}
.pk-practice-card{background:linear-gradient(180deg,rgba(10,18,14,.96),rgba(5,5,5,.96));box-shadow:0 30px 80px -30px rgba(0,0,0,.8);position:sticky;top:120px}
.pk-practice-row{display:flex;gap:24px;align-items:flex-start}
.pk-icon-box{display:grid;place-items:center;width:56px;height:56px;border-radius:14px;border:1px solid color-mix(in srgb,var(--pk-primary) 30%,transparent);background:color-mix(in srgb,var(--pk-primary) 8%,transparent);color:var(--pk-primary);flex-shrink:0}
.pk-icon{width:24px;height:24px}
.pk-practice-card .pk-h3{color:#fff;margin-top:8px}
.pk-practice-points{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-wrap:wrap;gap:8px}
.pk-practice-points li{padding:6px 12px;border-radius:999px;border:1px solid var(--pk-border);font-size:.78rem;color:rgba(255,255,255,.8)}

/* Process */
.pk-process-list{margin-top:64px;display:flex;flex-direction:column;gap:16px;max-width:880px;margin-left:auto;margin-right:auto}
.pk-process-item{display:flex;align-items:center;gap:24px;padding:24px}
.pk-process-item:hover{border-color:color-mix(in srgb,var(--pk-primary) 50%,transparent)}
.pk-process-num{display:grid;place-items:center;width:48px;height:48px;border-radius:999px;border:1px solid color-mix(in srgb,var(--pk-primary) 30%,transparent);background:color-mix(in srgb,var(--pk-primary) 8%,transparent);font-family:var(--pk-font-heading);color:var(--pk-primary);flex-shrink:0}
.pk-process-item .pk-h3{font-size:1.25rem}

/* Team */
.pk-team-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--pk-primary) 50%,transparent)}
.pk-team-photo{aspect-ratio:4/5;position:relative;overflow:hidden;background:radial-gradient(circle at 30% 20%,color-mix(in srgb,var(--pk-primary) 30%,transparent),transparent 60%),linear-gradient(135deg,#172a20,#0a0a0a);display:grid;place-items:center;filter:grayscale(1) brightness(.85) contrast(1.05);transition:filter .5s}
.pk-team-card:hover .pk-team-photo{filter:grayscale(0) brightness(1)}
.pk-initials{font-family:var(--pk-font-heading);font-size:4rem;color:rgba(255,255,255,.15)}
.pk-team-body{padding:20px}
.pk-team-body .pk-h3{color:#fff;font-size:1.1rem}
.pk-team-body .pk-index{margin-top:6px}
.pk-pill-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.pk-pill{padding:4px 10px;border-radius:999px;border:1px solid var(--pk-border);font-size:.7rem;color:rgba(255,255,255,.8)}

/* Blog posts */
.pk-post-card{overflow:hidden;padding:0;display:block;height:100%}
.pk-post-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--pk-primary) 50%,transparent)}
.pk-post-cover{aspect-ratio:16/10;position:relative;display:grid;place-items:end;padding:24px;color:#fff}
.pk-cover-shade{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.75))}
.pk-cover-label{position:absolute;left:20px;top:18px;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--pk-primary)}
.pk-cover-title{position:relative;font-family:var(--pk-font-heading);font-size:1.4rem;line-height:1.2;z-index:1}
.pk-post-body{padding:24px}
.pk-post-body .pk-h3{margin-top:12px;font-size:1.2rem}
.pk-post-meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--pk-muted);font-size:.85rem;align-items:center}
.pk-post-category{color:var(--pk-primary);letter-spacing:.25em;text-transform:uppercase;font-size:.72rem;font-weight:500}

/* CTA */
.pk-cta-box{max-width:840px;margin:0 auto;text-align:center;padding:64px 40px;border-radius:24px;border:1px solid color-mix(in srgb,var(--pk-primary) 30%,transparent);background:radial-gradient(circle at 50% 0%,color-mix(in srgb,var(--pk-primary) 22%,transparent),transparent 70%)}

/* Contact */
.pk-contact-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:900px){.pk-contact-grid{grid-template-columns:3fr 2fr}}
.pk-form label{display:block;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--pk-muted);margin-bottom:18px}
.pk-form input,.pk-form textarea{display:block;width:100%;margin-top:8px;padding:12px 14px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid var(--pk-border);color:var(--pk-text);font:inherit;text-transform:none;letter-spacing:0;transition:border-color .25s,background .25s}
.pk-form input:focus,.pk-form textarea:focus{outline:0;border-color:var(--pk-primary);background:rgba(255,255,255,.05)}
.pk-form-grid{display:grid;grid-template-columns:1fr;gap:0}
@media(min-width:600px){.pk-form-grid{grid-template-columns:1fr 1fr;gap:0 18px}}
.pk-contact-card{display:flex;gap:14px;align-items:flex-start;padding:20px}
.pk-success{color:#bff060;margin-bottom:14px}
.pk-error{color:#ff8585;margin-bottom:14px}

/* Footer */
.pk-footer{padding:80px 0 48px;border-top:1px solid var(--pk-border);background:rgba(0,0,0,.4);text-align:center;color:var(--pk-muted)}
.pk-footer-brand{font-family:var(--pk-font-heading);font-size:1.6rem;color:#fff;margin-bottom:14px}
.pk-footer-brand span{color:var(--pk-primary)}
.pk-footer ul{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:24px;padding:0;margin:24px 0 0}
.pk-footer a:hover{color:var(--pk-primary)}

/* Page (single page, e.g. About) */
.pk-page{padding:0}
.pk-front{display:block}

/* Single post */
article.pk-section .pk-post-cover{overflow:hidden}
article.pk-section .pk-post-cover img{width:100%;height:100%;object-fit:cover}

/* WhatsApp */
.pk-whatsapp{position:fixed;right:22px;bottom:22px;z-index:70;display:inline-flex;align-items:center;gap:10px;padding:14px 18px;border-radius:999px;background:linear-gradient(135deg,var(--pk-primary),#bff060);color:#0a120e;font-weight:700;font-size:.88rem;box-shadow:0 18px 40px -12px color-mix(in srgb,var(--pk-primary) 55%,transparent),0 4px 14px rgba(0,0,0,.4);transition:transform .3s,box-shadow .3s}
.pk-whatsapp:hover{transform:translateY(-2px) scale(1.03)}
.pk-whatsapp-pulse{position:absolute;inset:0;border-radius:999px;background:color-mix(in srgb,var(--pk-primary) 55%,transparent);z-index:-1;animation:pk-pulse 2.2s ease-out infinite}
@keyframes pk-pulse{0%{transform:scale(1);opacity:.6}80%,100%{transform:scale(1.4);opacity:0}}
@media(max-width:640px){.pk-whatsapp{padding:14px}.pk-whatsapp span:not(.pk-whatsapp-pulse){display:none}}

/* Motion background */
.pk-motion-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;background:
  radial-gradient(120% 60% at 50% 100%,color-mix(in srgb,var(--pk-primary) 8%,transparent),transparent 60%),
  radial-gradient(80% 50% at 50% 0%,rgba(20,30,22,.5),transparent 70%);
  will-change:transform;transition:transform .4s ease-out
}
.pk-graph-grid,.pk-grid{position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:120px 120px,120px 120px,24px 24px,24px 24px
}
.pk-radial{position:absolute;inset:0;background:radial-gradient(60% 35% at 50% 50%,rgba(30,40,30,.35),transparent 70%)}
.pk-waves{position:absolute;inset:0;background:repeating-linear-gradient(180deg,transparent,transparent 80px,rgba(255,255,255,.04) 80px,rgba(255,255,255,.04) 81px);animation:pk-waves 18s linear infinite}
@keyframes pk-waves{from{background-position:0 0}to{background-position:0 160px}}
.pk-aurora{position:absolute;inset:-20%;background:conic-gradient(from 90deg at 50% 50%,color-mix(in srgb,var(--pk-primary) 20%,transparent),transparent 60%);filter:blur(120px);animation:pk-spin 28s linear infinite}
@keyframes pk-spin{to{transform:rotate(360deg)}}
.pk-noise{position:absolute;inset:0;opacity:.15;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:3px 3px}
.pk-particles{position:absolute;inset:0;width:100%;height:100%}

/* Reveal animations */
.pk-reveal,.pk-reveal-scale,.pk-reveal-left,.pk-reveal-right{opacity:0;transition:opacity .9s ease,transform .9s ease;will-change:opacity,transform}
.pk-reveal{transform:translateY(40px)}
.pk-reveal-scale{transform:scale(.96)}
.pk-reveal-left{transform:translateX(-80px)}
.pk-reveal-right{transform:translateX(80px)}
.pk-reveal.is-visible,.pk-reveal-scale.is-visible,.pk-reveal-left.is-visible,.pk-reveal-right.is-visible{opacity:1;transform:none}
.pk-scroll-fill{color:#888;transition:color .6s}
.pk-scroll-fill.is-visible{color:#fff}

/* Custom cursor (desktop only) */
@media (hover:hover) and (pointer:fine){
  body.has-custom-cursor,body.has-custom-cursor *{cursor:none!important}
}
.pk-cursor-dot,.pk-cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:999px;will-change:transform}
.pk-cursor-dot{width:6px;height:6px;background:var(--pk-primary);box-shadow:0 0 10px color-mix(in srgb,var(--pk-primary) 80%,transparent)}
.pk-cursor-ring{width:34px;height:34px;border:1.5px solid color-mix(in srgb,var(--pk-primary) 80%,transparent);background:color-mix(in srgb,var(--pk-primary) 4%,transparent);transition:width .25s,height .25s,background .25s}
.pk-cursor-ring.is-hover{width:60px;height:60px;background:color-mix(in srgb,var(--pk-primary) 12%,transparent)}
@media(pointer:coarse){.pk-cursor-dot,.pk-cursor-ring{display:none}}

/* WordPress block / editor content inside .pk-page */
.pk-page > p,.pk-page > h2,.pk-page > h3,.pk-page > ul,.pk-page > ol{max-width:780px;margin-left:auto;margin-right:auto;padding:0 24px}
.pk-page .alignwide{max-width:1180px}
.pk-page .alignfull{max-width:100%}

/* Responsive tweaks */
@media(max-width:640px){
  .pk-section{padding:88px 0}
  .pk-hero{padding:120px 0 64px}
  .pk-container{padding:0 18px}
  .pk-card{padding:24px}
  .pk-process-item{flex-direction:column;align-items:flex-start;gap:14px}
  .pk-practice-card{position:relative;top:auto}
}
