/*
  Elevate Portfolio Addon v2.0
  Accent: #9747ff | BG: #050816 | Text: #ffffff
  Most styling is inline on widgets for Elementor override protection.
  This file handles: animations, hovers, transitions, responsive.
*/

/* ── KEYFRAMES ── */
@keyframes epSpin { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes epPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.8)} }
@keyframes epFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
@keyframes epFadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

/* ── GLOBAL ── */
.ep-dot { width:6px;height:6px;border-radius:50%;display:inline-block;animation:epPulse 2s infinite; }

/* ── HERO ── */
.ep-hero { position:relative;overflow:hidden;text-align:center; }
.ep-hero-grid { position:absolute;inset:0;background-image:linear-gradient(rgba(151,71,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(151,71,255,.03) 1px,transparent 1px);background-size:70px 70px;-webkit-mask-image:radial-gradient(ellipse 65% 55% at 50% 35%,black 30%,transparent 75%);mask-image:radial-gradient(ellipse 65% 55% at 50% 35%,black 30%,transparent 75%);pointer-events:none; }
.ep-hero-orb1 { position:absolute;width:650px;height:650px;border-radius:50%;filter:blur(120px);top:-200px;left:50%;transform:translateX(-50%);pointer-events:none; }
.ep-hero-orb2 { position:absolute;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(34,211,238,.08),transparent);filter:blur(100px);bottom:-80px;right:5%;pointer-events:none; }
.ep-hero-inner { position:relative;z-index:2;max-width:900px;margin:0 auto; }

.ep-badge { display:inline-flex !important;align-items:center;gap:8px;padding:8px 22px;border-radius:50px;font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:28px;animation:epFadeUp .7s ease both; }
.ep-h1 { font-family:'Manrope',sans-serif !important;font-weight:800 !important;font-size:clamp(3rem,6.5vw,5.2rem) !important;line-height:1.05 !important;letter-spacing:-3px !important;margin:0 0 22px !important;animation:epFadeUp .7s ease .08s both; }
.ep-h1 i { font-family:'Playfair Display',serif !important;font-style:italic !important;font-weight:700 !important; }
.ep-gr { background:linear-gradient(135deg,#9747ff,#c084fc,#22d3ee) !important;-webkit-background-clip:text !important;-webkit-text-fill-color:transparent !important;background-clip:text !important; }
.ep-hero-p { font-size:1.1rem !important;max-width:580px;margin:0 auto !important;line-height:1.65 !important;animation:epFadeUp .7s ease .15s both; }
.ep-stats-row { display:flex;justify-content:center;gap:56px;margin-top:40px;animation:epFadeUp .7s ease .22s both; }
.ep-stat-v { font-weight:800;font-size:2.4rem;letter-spacing:-1.5px;background:linear-gradient(135deg,#9747ff,#c084fc,#22d3ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2; }
.ep-stat-l { font-size:11px;text-transform:uppercase;letter-spacing:2px;margin-top:2px; }

/* ── SECTION HEADERS ── */
.ep-stag { font-family:'IBM Plex Mono',monospace !important;font-size:11px !important;letter-spacing:2.5px !important;text-transform:uppercase;display:flex;align-items:center;gap:10px;margin-bottom:16px; }
.ep-stag::before { content:'';width:24px;height:1px;background:currentColor; }
.ep-stitle { font-family:'Manrope',sans-serif !important;font-weight:800 !important;font-size:clamp(2rem,3.5vw,2.8rem) !important;letter-spacing:-1.5px !important;line-height:1.1 !important;margin:0 0 12px !important; }

/* ── PROJECT CARDS ── */
.ep-pgrid { display:grid !important; }
.ep-pcard { display:block;border:1px solid rgba(151,71,255,.08);border-radius:18px;overflow:hidden;cursor:pointer;transition:all .45s cubic-bezier(.16,1,.3,1);text-decoration:none !important; }
.ep-pcard:hover { transform:translateY(-8px);border-color:rgba(151,71,255,.25);box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 1px rgba(151,71,255,.1); }

.ep-pcard-vis { position:relative;width:100%;aspect-ratio:16/10;overflow:hidden; }
.ep-pcard-vis > *:not(.ep-pcard-industry):not(.ep-mock-sm) { position:absolute;inset:0;transition:transform .6s cubic-bezier(.16,1,.3,1); }
.ep-pcard:hover .ep-pcard-vis > *:first-child { transform:scale(1.06); }

.ep-pcard-industry { position:absolute;top:14px;left:14px;z-index:2;padding:4px 14px;border-radius:50px;font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;border-width:1px;border-style:solid; }

.ep-pcard-body { padding:26px 24px 28px; }
.ep-pcard-body h3 { font-weight:700 !important;font-size:1.15rem !important;letter-spacing:-.3px;margin:0 0 8px !important;transition:.3s; }
.ep-pcard:hover h3 { color:#c084fc !important; }
.ep-pcard-desc { font-size:13px !important;line-height:1.6 !important;margin:0 0 16px !important; }

.ep-pcard-mets { display:flex;gap:8px;margin-bottom:16px; }
.ep-pmet { flex:1;border:1px solid rgba(151,71,255,.08);border-radius:10px;padding:10px 8px;text-align:center; }
.ep-pmet-v { font-weight:800;font-size:15px;letter-spacing:-.3px;color:#c084fc; }
.ep-pmet-l { font-size:9px;text-transform:uppercase;letter-spacing:1px;margin-top:1px; }

.ep-pcard-foot { display:flex;justify-content:space-between;align-items:center; }
.ep-ptechs { display:flex;gap:5px;flex-wrap:wrap; }
.ep-ptech { padding:3px 10px;border-radius:50px;font-family:'IBM Plex Mono',monospace;font-size:10px;border:1px solid rgba(255,255,255,.04); }
.ep-parrow { width:34px;height:34px;border-radius:50%;border-width:1px;border-style:solid;display:flex;align-items:center;justify-content:center;font-size:13px;transition:.3s; }
.ep-pcard:hover .ep-parrow { background:#9747ff !important;border-color:#9747ff !important;color:#fff !important;transform:rotate(-45deg); }

/* Browser mockup */
.ep-mock-sm { position:absolute;width:78%;height:75%;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:10px;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.08);overflow:hidden;backdrop-filter:blur(8px); }
.ep-mock-bar-sm { height:24px;background:rgba(0,0,0,.35);display:flex;align-items:center;gap:4px;padding:0 9px; }
.ep-md { width:6px;height:6px;border-radius:50%;display:inline-block; }
.ep-md.r { background:#ff5f57; }
.ep-md.y { background:#febc2e; }
.ep-md.g { background:#28c840; }
.ep-mock-url-sm { margin-left:8px;height:11px;width:100px;border-radius:6px;background:rgba(255,255,255,.06); }
.ep-mock-bd-sm { padding:10px; }
.ep-mln { height:4px;border-radius:3px;background:rgba(255,255,255,.07);margin-bottom:5px; }
.ep-mhero { height:36px;border-radius:5px;background:rgba(255,255,255,.025);margin-top:5px; }
.ep-mcols { display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-top:5px; }
.ep-mblk { height:24px;border-radius:4px;background:rgba(255,255,255,.035); }

/* ── LEAD SECTION ── */
.ep-lb-item:first-child { border-top:1px solid rgba(255,255,255,.04) !important; }
.ep-lb-item:hover { padding-left:10px !important; }
.ep-fcard input:focus,.ep-fcard select:focus,.ep-fcard textarea:focus { border-color:#9747ff !important;box-shadow:0 0 0 3px rgba(151,71,255,.12) !important; }
.ep-fcard button:hover { box-shadow:0 4px 28px rgba(151,71,255,.35) !important;transform:translateY(-1px); }

/* ── CTA ── */
.ep-btn-primary:hover { box-shadow:0 4px 28px rgba(151,71,255,.35) !important;transform:translateY(-2px); }

/* ── SCROLL REVEAL ── */
.ep-reveal { opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1); }
.ep-reveal.ep-vis { opacity:1;transform:translateY(0); }

/* ── SCROLLBAR (global) ── */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:#050816; }
::-webkit-scrollbar-thumb { background:#9747ff;border-radius:9px; }
::selection { background:#9747ff;color:#fff; }

/* ── RESPONSIVE ── */
@media(max-width:1024px) {
  .ep-pgrid { grid-template-columns:repeat(2,1fr) !important; }
  .ep-lead-grid { grid-template-columns:1fr !important; }
  .ep-steps-wrap { grid-template-columns:repeat(3,1fr) !important;gap:32px !important; }
}
@media(max-width:768px) {
  .ep-stats-row { gap:24px;flex-wrap:wrap; }
  .ep-stat-v { font-size:1.8rem; }
  .ep-pgrid { grid-template-columns:1fr !important; }
  .ep-steps-wrap { grid-template-columns:1fr 1fr !important;gap:28px !important; }
  .ep-frow { grid-template-columns:1fr !important; }
  .ep-pcard-mets { flex-wrap:wrap; }
}

/* ── Elementor reset overrides ── */
.elementor-widget-ep_hero .elementor-widget-container,
.elementor-widget-ep_project_grid .elementor-widget-container,
.elementor-widget-ep_process_steps .elementor-widget-container,
.elementor-widget-ep_lead_section .elementor-widget-container,
.elementor-widget-ep_cta_box .elementor-widget-container,
.elementor-widget-ep_stats_bar .elementor-widget-container {
  padding: 0 !important;
  margin: 0 !important;
}
