/*
Theme Name: Prakala Legal
Theme URI: https://prakalalegal.com
Author: Prakala Legal
Author URI: https://prakalalegal.com
Description: Premium dark-themed luxury law firm WordPress theme for Prakala Legal. Inspired by McKinsey meets Apple aesthetics with lime accents, glassmorphism, and modern typography.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: prakala-legal
Tags: dark, business, blog, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* Base reset & tokens */
:root{
  --bg:#050505;
  --surface:#0b0b0c;
  --card:#111113;
  --border:#1d1d20;
  --muted:#8a8a92;
  --fg:#f5f5f7;
  --primary:#d6ff32;
  --primary-fg:#0a0a0a;
  --radius:14px;
  --maxw:1240px;
  --font-display:'Inter',system-ui,-apple-system,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--bg);color:var(--fg);font-family:var(--font-body);line-height:1.6;font-size:16px;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:opacity .2s}
a:hover{opacity:.8}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;letter-spacing:-0.03em;line-height:1.05}
h1{font-size:clamp(2.6rem,7vw,6.5rem)}
h2{font-size:clamp(2rem,4.5vw,3.8rem)}
h3{font-size:clamp(1.3rem,2vw,1.6rem)}
p{color:#d6d6da}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* Grid bg */
.grid-bg{background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:60px 60px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:999px;font-weight:500;font-size:14px;letter-spacing:.02em;transition:transform .2s, box-shadow .2s}
.btn-primary{background:var(--primary);color:var(--primary-fg);box-shadow:0 0 40px -10px var(--primary)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 60px -8px var(--primary)}
.btn-ghost{border:1px solid var(--border);color:var(--fg)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}

/* Eyebrow tag */
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.03);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--primary);box-shadow:0 0 12px var(--primary)}

/* Navigation */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(16px);background:rgba(5,5,5,.7);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;max-width:var(--maxw);margin:0 auto}
.brand{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-.02em}
.brand span{color:var(--primary)}
.nav-menu{display:flex;gap:36px;list-style:none}
.nav-menu a{font-size:14px;color:var(--muted)}
.nav-menu a:hover{color:var(--fg)}
.nav-toggle{display:none;font-size:24px}
@media(max-width:900px){
  .nav-menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--bg);padding:24px;border-bottom:1px solid var(--border)}
  .nav-menu.open{display:flex}
  .nav-toggle{display:block}
}

/* Hero */
.hero{position:relative;padding:180px 0 120px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse at top,#000,transparent 70%);opacity:.5}
.hero::after{content:"";position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:700px;height:700px;border-radius:50%;background:rgba(214,255,50,.08);filter:blur(140px);pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}}
.hero h1{margin:24px 0;text-wrap:balance}
.hero h1 em{font-style:normal;color:var(--primary);font-family:'Playfair Display',serif;font-weight:400}
.hero-lead{font-size:18px;color:var(--muted);max-width:560px;margin-bottom:36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{position:relative;aspect-ratio:4/5;border-radius:24px;overflow:hidden;border:1px solid var(--border)}
.hero-visual img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) contrast(1.1)}
.hero-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(5,5,5,.8),transparent 60%)}
.metric-card{position:absolute;background:rgba(11,11,12,.85);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:14px;padding:18px 22px;z-index:2}
.metric-card .num{font-family:var(--font-display);font-size:32px;font-weight:600;color:var(--primary)}
.metric-card .lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.metric-card.m1{top:30px;left:-20px}
.metric-card.m2{bottom:60px;right:-30px}

/* Marquee */
.marquee{padding:36px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;background:rgba(255,255,255,.01)}
.marquee-track{display:flex;gap:80px;animation:scroll 30s linear infinite;white-space:nowrap}
.marquee-track span{font-family:var(--font-display);font-size:28px;font-weight:500;color:var(--muted);letter-spacing:-.02em}
.marquee-track span em{color:var(--primary);font-style:normal;margin:0 8px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Sections */
section{padding:120px 0;position:relative}
.section-head{max-width:780px;margin-bottom:64px}
.section-head h2{margin:20px 0;text-wrap:balance}
.section-head p{font-size:18px;color:var(--muted)}

/* Metrics */
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
@media(max-width:900px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}
.metric{border-top:1px solid var(--border);padding-top:24px}
.metric .big{font-family:var(--font-display);font-size:clamp(2.5rem,5vw,4rem);font-weight:600;color:var(--fg);letter-spacing:-.04em}
.metric .big sup{color:var(--primary);font-size:.5em;vertical-align:super}
.metric .lbl{margin-top:8px;font-size:13px;color:var(--muted);letter-spacing:.05em}

/* Practice / cards grid */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.cards-grid{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:36px 30px;transition:transform .3s, border-color .3s, background .3s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-6px);border-color:var(--primary);background:#131316}
.card .ico{width:48px;height:48px;border-radius:12px;background:rgba(214,255,50,.1);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:22px;margin-bottom:24px}
.card h3{margin-bottom:12px}
.card p{font-size:15px;color:var(--muted)}
.card .arrow{position:absolute;top:30px;right:30px;color:var(--muted);transition:color .2s, transform .2s}
.card:hover .arrow{color:var(--primary);transform:translate(4px,-4px)}

/* About split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.split-img{border-radius:20px;overflow:hidden;border:1px solid var(--border);aspect-ratio:4/5}
.split-img img{width:100%;height:100%;object-fit:cover}
.split-content h2{margin:20px 0 24px}
.split-content p{margin-bottom:18px;font-size:17px}

/* Process timeline */
.timeline{position:relative;padding-left:40px;border-left:1px solid var(--border)}
.timeline-item{position:relative;padding:0 0 56px 40px}
.timeline-item:last-child{padding-bottom:0}
.timeline-item::before{content:"";position:absolute;left:-46px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--primary);box-shadow:0 0 24px var(--primary)}
.timeline-item .step{font-size:11px;letter-spacing:.25em;color:var(--primary);text-transform:uppercase;margin-bottom:10px}
.timeline-item h3{margin-bottom:10px}
.timeline-item p{color:var(--muted)}

/* Insights / posts */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
@media(max-width:900px){.posts-grid{grid-template-columns:1fr}}
.post-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .3s, border-color .3s}
.post-card:hover{transform:translateY(-6px);border-color:var(--primary)}
.post-card-thumb{aspect-ratio:16/10;overflow:hidden;background:#181818}
.post-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.post-card:hover .post-card-thumb img{transform:scale(1.05)}
.post-card-body{padding:26px}
.post-card .meta{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--primary);margin-bottom:12px}
.post-card h3{font-size:1.25rem;margin-bottom:10px}
.post-card .excerpt{font-size:14px;color:var(--muted)}

/* FAQ */
.faq-item{border-bottom:1px solid var(--border);padding:24px 0}
.faq-q{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-family:var(--font-display);font-size:1.15rem;font-weight:500}
.faq-q .plus{color:var(--primary);font-size:24px;transition:transform .3s}
.faq-item.open .faq-q .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s}
.faq-item.open .faq-a{max-height:400px;padding-top:16px}
.faq-a p{color:var(--muted)}

/* Contact */
.contact{background:linear-gradient(180deg,transparent,rgba(214,255,50,.04))}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-info p{margin-bottom:14px}
.contact-info strong{display:block;color:var(--primary);font-size:12px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:4px}
.form-field{margin-bottom:18px}
.form-field label{display:block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.form-field input,.form-field textarea,.form-field select{width:100%;padding:14px 18px;background:var(--card);border:1px solid var(--border);border-radius:10px;color:var(--fg);font:inherit;font-size:15px;transition:border-color .2s}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--primary)}
.form-field textarea{min-height:130px;resize:vertical}

/* Footer */
.site-footer{border-top:1px solid var(--border);padding:80px 0 40px;background:var(--surface)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-grid h4{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:20px;font-weight:500}
.footer-grid ul{list-style:none}
.footer-grid li{margin-bottom:10px;font-size:14px;color:#aaa}
.footer-bottom{border-top:1px solid var(--border);padding-top:30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--muted)}

/* Disclaimer modal */
.disclaimer{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:24px}
.disclaimer.hidden{display:none}
.disclaimer-box{max-width:640px;background:var(--card);border:1px solid var(--border);border-radius:18px;padding:40px}
.disclaimer-box h2{font-size:1.6rem;margin-bottom:20px;color:var(--primary)}
.disclaimer-box p{font-size:14px;margin-bottom:14px;color:#bbb}
.disclaimer-box .actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}

/* Reveal animation */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
[data-reveal].in{opacity:1;transform:none}

/* Single post / page */
.page-hero{padding:160px 0 60px;border-bottom:1px solid var(--border)}
.page-hero .eyebrow{margin-bottom:20px}
.page-hero h1{font-size:clamp(2.4rem,5vw,4.5rem)}
.content-body{max-width:760px;margin:0 auto;padding:60px 24px}
.content-body p,.content-body li{font-size:17px;line-height:1.8;color:#d6d6da;margin-bottom:20px}
.content-body h2,.content-body h3{margin:40px 0 16px}
.content-body img{border-radius:14px;margin:30px 0}
.content-body a{color:var(--primary);text-decoration:underline}
.content-body blockquote{border-left:3px solid var(--primary);padding:8px 0 8px 24px;margin:30px 0;font-style:italic;color:#bbb}
.content-body code{background:var(--card);padding:2px 8px;border-radius:6px;font-size:.9em}

/* WhatsApp floating button */
.wa-float{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 36px -8px rgba(37,211,102,.5);z-index:999;transition:transform .25s}
.wa-float:hover{transform:scale(1.08);opacity:1}

/* Booking page */
.booking-wrap{max-width:820px;margin:0 auto;padding:60px 24px 120px}
.booking-form{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:40px}
@media(max-width:700px){.booking-form{padding:24px}}
.booking-steps{display:flex;gap:8px;margin-bottom:30px;flex-wrap:wrap}
.booking-steps .step{flex:1;min-width:100px;text-align:center;padding:10px;border:1px solid var(--border);border-radius:10px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.booking-steps .step.active{border-color:var(--primary);color:var(--primary);background:rgba(214,255,50,.06)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid .full{grid-column:1/-1}
@media(max-width:700px){.form-grid{grid-template-columns:1fr}}
.booking-success{text-align:center;padding:60px 30px;background:var(--card);border:1px solid var(--primary);border-radius:20px}
.booking-success .ico{width:72px;height:72px;border-radius:50%;background:rgba(214,255,50,.1);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 24px}
.booking-success h2{font-size:2rem;margin-bottom:14px}
.booking-success p{color:var(--muted);max-width:480px;margin:0 auto}
