/* ================================================================
   PORTFOLIO PAGE — CodeScriptum
   Standalone page styles (matching O nas / Oferta design system)
   ================================================================ */

/* ── Reset & Variables ────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --indigo:#4F46E5;
  --indigo-dark:#3730A3;
  --electric:#6366F1;
  --cyan:#06B6D4;
  --cyan-light:#22D3EE;
  --neon:#A78BFA;
  --neon-light:#C4B5FD;
  --emerald:#10B981;
  --orange:#F59E0B;
  --rose:#F43F5E;
  --dark:#030712;
  --dark-800:#0B0F1A;
  --dark-card:#111827;
  --dark-surface:#1F2937;
  --gray-100:#F8FAFC;
  --gray-200:#E2E8F0;
  --gray-300:#CBD5E1;
  --gray-400:#94A3B8;
  --gray-500:#64748B;
  --white:#FFFFFF;
  --font:'Inter',system-ui,sans-serif;
  --font-display:'Space Grotesk','Inter',sans-serif;
  --section-py:110px;
  --container:1200px;
  --radius:16px;
  --radius-sm:10px;
}

html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font);color:var(--gray-100);background:var(--dark);line-height:1.7;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* ── Gradient text ────────────────────────────────────────────── */
.gradient-text{
  background:linear-gradient(135deg,var(--cyan-light),var(--electric),var(--neon));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  background-size:200% 200%;
  animation:gradientShift 4s ease-in-out infinite;
}
@keyframes gradientShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* ── Buttons (full set matching O nas) ────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;border-radius:50px;font-weight:600;font-size:.95rem;
  cursor:pointer;border:none;transition:all .35s cubic-bezier(.25,.8,.25,1);
  font-family:var(--font);position:relative;overflow:hidden;
  text-decoration:none;
}
.btn--primary{
  background:linear-gradient(135deg,var(--indigo),var(--electric));color:#fff;
  box-shadow:0 4px 20px rgba(99,102,241,.3);
}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(99,102,241,.5)}
.btn--ghost{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:#fff;
  backdrop-filter:blur(10px);
}
.btn--ghost:hover{background:rgba(99,102,241,.1);border-color:var(--electric);transform:translateY(-3px)}
.btn--glow::before{
  content:'';position:absolute;inset:-2px;border-radius:inherit;
  background:linear-gradient(135deg,var(--cyan),var(--electric),var(--neon));
  z-index:-1;opacity:0;transition:opacity .4s;filter:blur(15px);
}
.btn--glow:hover::before{opacity:.6}
.btn--full{width:100%;justify-content:center}
.btn--sm{padding:10px 22px;font-size:.88rem}
.btn--lg{font-size:.95rem;padding:16px 36px}
.btn__text,.btn__loader{display:flex;align-items:center;gap:8px}
.btn__loader{display:none}
.btn.loading .btn__text{display:none}
.btn.loading .btn__loader{display:flex}
.btn--white{
  background:#fff;color:#1e1b4b;border:none;
  padding:14px 32px;border-radius:50px;
  font-size:.9rem;font-weight:700;
  box-shadow:0 4px 20px rgba(255,255,255,.15);
  transition:all .35s cubic-bezier(.4,0,.2,1);
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;
}
.btn--white:hover{
  background:#f0ecff;transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(255,255,255,.2);
}
.btn--ghost-light{
  background:transparent;color:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.15);
  padding:14px 32px;border-radius:50px;
  font-size:.9rem;font-weight:600;
  transition:all .3s ease;
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;
}
.btn--ghost-light:hover{
  border-color:var(--electric);color:#fff;
}
.btn--outline-light{
  background:transparent;color:rgba(255,255,255,.6);
  border:1px solid rgba(255,255,255,.12);
  padding:10px 24px;border-radius:50px;
  font-size:.85rem;font-weight:600;
  transition:all .3s ease;
  display:inline-flex;align-items:center;gap:6px;
  text-decoration:none;
}
.btn--outline-light:hover{
  border-color:rgba(99,102,241,.4);color:#fff;
}

/* ── Sections ─────────────────────────────────────────────────── */
.section{padding:var(--section-py) 0;position:relative;overflow:hidden}
.section--dark{background:var(--dark)}
.section--light{background:var(--gray-100);color:var(--dark)}
.section--gradient{
  background:linear-gradient(135deg,var(--dark-800) 0%,#1a1040 50%,var(--dark-800) 100%);
}
.section__title{
  text-align:center;font-size:clamp(1.8rem,4vw,2.8rem);
  font-family:var(--font-display);margin-bottom:16px;
}
.section__title--light{color:#fff}
.section__subtitle{
  text-align:center;font-size:1.05rem;color:var(--gray-400);
  max-width:640px;margin:0 auto 50px;
}
.section__subtitle--light{color:rgba(255,255,255,.6)}

/* ── HERO ─────────────────────────────────────────────────────── */
.pf-hero{
  position:relative;min-height:70vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;padding:140px 0 80px;overflow:hidden;
}
.pf-hero__bg{position:absolute;inset:0;z-index:0}
.pf-hero__canvas{position:absolute;inset:0;width:100%;height:100%}
.pf-hero__aurora{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 20% 80%,rgba(99,102,241,.12),transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 20%,rgba(6,182,212,.08),transparent 50%),
    radial-gradient(ellipse 50% 50% at 50% 50%,rgba(167,139,250,.06),transparent 60%);
}
.pf-hero__grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(99,102,241,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(99,102,241,.04) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,#000 30%,transparent 70%);
}
.pf-hero__orb{
  position:absolute;border-radius:50%;filter:blur(80px);
  animation:orbFloat 8s ease-in-out infinite alternate;
}
.pf-hero__orb--1{
  width:400px;height:400px;top:-100px;right:-100px;
  background:radial-gradient(circle,rgba(99,102,241,.15),transparent 70%);
}
.pf-hero__orb--2{
  width:350px;height:350px;bottom:-80px;left:-80px;
  background:radial-gradient(circle,rgba(6,182,212,.12),transparent 70%);
  animation-delay:-4s;
}
@keyframes orbFloat{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(30px,-20px) scale(1.05)}
}

.pf-hero__inner{position:relative;z-index:1;max-width:800px;margin:0 auto}

.pf-hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 20px;border-radius:50px;font-size:.85rem;font-weight:500;
  background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.2);
  color:var(--neon-light);margin-bottom:28px;
}
.pf-hero__badge-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--emerald);
  box-shadow:0 0 8px var(--emerald);
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.pf-hero__title{
  font-size:clamp(2.2rem,5vw,3.6rem);
  font-family:var(--font-display);
  font-weight:800;line-height:1.15;margin-bottom:24px;
}
.pf-hero__subtitle{
  font-size:clamp(1rem,1.8vw,1.2rem);
  color:rgba(255,255,255,.65);line-height:1.8;margin-bottom:36px;
}
.pf-hero__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ── MARQUEE ──────────────────────────────────────────────────── */
.marquee{
  overflow:hidden;
  background:rgba(99,102,241,.04);
  border-top:1px solid rgba(99,102,241,.08);
  border-bottom:1px solid rgba(99,102,241,.08);
  padding:14px 0;
}
.marquee__track{
  display:flex;gap:40px;
  animation:marqueeScroll 30s linear infinite;
  width:max-content;
}
.marquee__item{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.85rem;font-weight:600;color:rgba(255,255,255,.4);
  white-space:nowrap;
}
.marquee__item i{color:var(--electric);font-size:.8rem}
@keyframes marqueeScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ── CATEGORY NAV (sticky pills) ─────────────────────────────── */
.pf-nav{
  position:sticky;top:0;z-index:100;
  background:rgba(10,10,30,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(99,102,241,.1);
  padding:14px 0;
  overflow:visible;
}
.pf-nav .container{
  max-width:100%;padding:0 24px;
}
.pf-nav__track{
  display:flex;gap:8px;overflow-x:auto;
  scrollbar-width:none;-ms-overflow-style:none;
  padding:0 8px;
  -webkit-overflow-scrolling:touch;
}
.pf-nav__track::-webkit-scrollbar{display:none}
.pf-nav__pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:50px;white-space:nowrap;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.55);font-size:.82rem;font-weight:600;
  text-decoration:none;transition:all .3s ease;flex-shrink:0;
}
.pf-nav__pill:hover{
  background:rgba(99,102,241,.12);border-color:rgba(99,102,241,.25);
  color:rgba(255,255,255,.9);
}
.pf-nav__pill.active{
  background:linear-gradient(135deg,#6366F1,#818CF8);border-color:transparent;
  color:#fff;box-shadow:0 4px 20px rgba(99,102,241,.35);
}
.pf-nav__pill i{font-size:.75rem}

/* ── PORTFOLIO SECTIONS ──────────────────────────────────────── */
.pf-section{
  padding:80px 0 60px;
  background:linear-gradient(180deg,#060618 0%,#0a0a2e 50%,#060618 100%);
  border-bottom:1px solid rgba(255,255,255,.04);
  position:relative;overflow:hidden;
}
/* Particles canvas */
.pf-section__particles{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:0;
}
.pf-section > .container{position:relative;z-index:1;
}
.pf-section:nth-child(even){
  background:linear-gradient(180deg,#0a0a2e 0%,#0d0d35 50%,#0a0a2e 100%);
}

.pf-section__header{
  display:flex;align-items:center;gap:18px;margin-bottom:48px;
}
.pf-section__icon{
  width:56px;height:56px;border-radius:16px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--pf-gradient);color:#fff;font-size:1.3rem;
  box-shadow:0 4px 24px rgba(99,102,241,.3);
}
.pf-section__title{
  font-family:var(--font-display);font-size:1.75rem;
  font-weight:700;color:#fff;margin:0 0 4px;
}
.pf-section__subtitle{
  font-size:.9rem;color:rgba(255,255,255,.4);margin:0;
  text-align:left;max-width:none;
}

/* ── PORTFOLIO GRID — 3 columns ──────────────────────────────── */
.pf-grid{
  display:grid;gap:24px;
}
.pf-grid--image{
  grid-template-columns:repeat(3,1fr);
}
.pf-grid--icon{
  grid-template-columns:repeat(3,1fr);
}

/* ── CARD — clickable link reset ──────────────────────────────── */
a.pf-card{text-decoration:none;color:inherit;display:block;cursor:pointer}

/* ── CARD — IMAGE VARIANT ────────────────────────────────────── */
.pf-card--image{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);overflow:hidden;
  transition:all .4s cubic-bezier(.4,0,.2,1);
}
.pf-card--image:hover{
  border-color:rgba(99,102,241,.3);
  transform:translateY(-6px);
  box-shadow:0 16px 50px rgba(0,0,0,.35),0 0 40px rgba(99,102,241,.1);
}

.pf-card__image{
  position:relative;overflow:hidden;
  aspect-ratio:16/10;
}
.pf-card__image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;
}
.pf-card--image:hover .pf-card__image img{
  transform:scale(1.05);
}
.pf-card__overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.7) 100%);
  display:flex;align-items:flex-end;padding:16px;
}
.pf-card__client{
  font-size:.78rem;font-weight:600;color:rgba(255,255,255,.85);
  background:rgba(0,0,0,.45);backdrop-filter:blur(8px);
  padding:4px 12px;border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
}

.pf-card__body{padding:20px}
.pf-card__title{
  font-family:var(--font-display);font-size:1rem;
  font-weight:700;color:#fff;margin:0 0 8px;line-height:1.3;
}
.pf-card__desc{
  font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.55;
  margin:0 0 14px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}

/* Stats row */
.pf-card__stats{
  display:flex;gap:16px;margin-bottom:12px;
}
.pf-card__stat{
  display:flex;flex-direction:column;
}
.pf-card__stat-val{
  font-family:var(--font-display);font-size:.95rem;
  font-weight:700;color:var(--pf-color,var(--electric));
  text-shadow:0 0 12px currentColor;
}
.pf-card__stat-lbl{
  font-size:.7rem;color:rgba(255,255,255,.35);
}

/* Tech tags */
.pf-card__techs{
  display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;
}
.pf-card__tech{
  font-size:.68rem;font-weight:600;
  padding:3px 10px;border-radius:20px;
  background:rgba(99,102,241,.1);color:rgba(255,255,255,.6);
  border:1px solid rgba(99,102,241,.15);
}

/* ── CARD — ICON VARIANT (enhanced design) ───────────────────── */
.pf-card--icon{
  background:linear-gradient(165deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.015) 100%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:0;
  transition:all .45s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
/* Top accent gradient bar */
.pf-card--icon::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--pf-gradient);border-radius:var(--radius) var(--radius) 0 0;
  opacity:.7;transition:opacity .35s,height .35s;
}
/* Decorative corner glow */
.pf-card--icon::after{
  content:'';position:absolute;top:-40px;right:-40px;
  width:120px;height:120px;border-radius:50%;
  background:var(--pf-gradient);opacity:.04;
  filter:blur(30px);transition:opacity .4s,transform .4s;
  pointer-events:none;
}
.pf-card--icon:hover::before{opacity:1;height:4px}
.pf-card--icon:hover::after{opacity:.1;transform:scale(1.3)}
.pf-card--icon:hover{
  border-color:var(--pf-color);transform:translateY(-8px);
  box-shadow:
    0 20px 50px rgba(0,0,0,.4),
    0 0 40px rgba(99,102,241,.08),
    inset 0 1px 0 rgba(255,255,255,.06);
  background:linear-gradient(165deg,rgba(255,255,255,.07) 0%,rgba(255,255,255,.02) 100%);
}

/* Card inner padding wrapper */
.pf-card--icon .pf-card__header{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
  padding:28px 28px 0;margin-bottom:16px;position:relative;z-index:1;
}
.pf-card__icon{flex-shrink:0}
.pf-card__icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:var(--pf-gradient);color:#fff;font-size:1.25rem;
  box-shadow:0 6px 20px color-mix(in srgb,var(--pf-color) 35%,transparent);
  position:relative;
}
/* Icon glow ring */
.pf-card--icon:hover .pf-card__icon{
  box-shadow:
    0 6px 20px color-mix(in srgb,var(--pf-color) 35%,transparent),
    0 0 0 6px color-mix(in srgb,var(--pf-color) 10%,transparent);
}
.pf-card__tags{
  display:flex;gap:5px;flex-wrap:wrap;
}
.pf-card__tag{
  font-size:.68rem;font-weight:600;letter-spacing:.02em;
  padding:4px 12px;border-radius:20px;
  background:color-mix(in srgb,var(--pf-color) 8%,transparent);
  color:color-mix(in srgb,var(--pf-color) 70%,#fff);
  border:1px solid color-mix(in srgb,var(--pf-color) 15%,transparent);
  transition:all .3s ease;
}
.pf-card--icon:hover .pf-card__tag{
  background:color-mix(in srgb,var(--pf-color) 12%,transparent);
  border-color:color-mix(in srgb,var(--pf-color) 25%,transparent);
}

.pf-card--icon .pf-card__title{
  position:relative;z-index:1;
  font-family:var(--font-display);font-size:1.1rem;
  font-weight:700;color:#fff;margin:0 0 4px;
  padding:0 28px;line-height:1.35;
}
.pf-card__client-label{
  display:inline-block;font-size:.76rem;color:var(--pf-color);
  font-weight:600;margin:0 28px 12px;position:relative;z-index:1;
  padding:2px 0;
  border-bottom:1px dashed color-mix(in srgb,var(--pf-color) 25%,transparent);
}
.pf-card--icon .pf-card__desc{
  font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.6;
  margin:0;padding:0 28px 28px;position:relative;z-index:1;
  flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
  overflow:hidden;
}

/* Stats bar — full-width bottom section */
.pf-card--icon .pf-card__stats{
  position:relative;z-index:1;
  display:flex;gap:0;
  margin-top:auto;
  background:rgba(255,255,255,.025);
  border-top:1px solid rgba(255,255,255,.06);
}
.pf-card--icon .pf-card__stat{
  flex:1;display:flex;flex-direction:column;align-items:center;
  padding:16px 12px;text-align:center;
  border-right:1px solid rgba(255,255,255,.04);
}
.pf-card--icon .pf-card__stat:last-child{border-right:none}
.pf-card--icon .pf-card__stat-val{
  font-size:.95rem;font-weight:800;color:var(--pf-color);
  text-shadow:0 0 20px color-mix(in srgb,var(--pf-color) 30%,transparent);
  letter-spacing:-.01em;
}
.pf-card--icon .pf-card__stat-lbl{
  font-size:.65rem;color:rgba(255,255,255,.35);
  margin-top:2px;line-height:1.3;
}

/* ── LIGHT THEME OVERRIDE ────────────────────────────────────── */
/* When pf-cards are embedded in light-background sections (landing pages) */
.section--light .pf-grid--image{
  grid-template-columns:repeat(3,1fr);
}
.section--light .pf-card--image{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:var(--radius);
  box-shadow:0 4px 20px rgba(0,0,0,.06);
}
.section--light .pf-card--image:hover{
  border-color:var(--pf-color,var(--electric));
  transform:translateY(-8px);
  box-shadow:0 20px 50px rgba(0,0,0,.1),0 0 30px rgba(99,102,241,.08);
}
.section--light .pf-card__body{padding:22px 24px}
.section--light .pf-card__title{
  color:#0f172a;
}
.section--light .pf-card__desc{
  color:#64748b;
}
.section--light .pf-card__stats{
  margin-bottom:14px;
  padding-top:14px;
  border-top:1px solid #e2e8f0;
}
.section--light .pf-card__stat-val{
  color:var(--pf-color,#4f46e5);
  text-shadow:none;
}
.section--light .pf-card__stat-lbl{
  color:#94a3b8;
}
.section--light .pf-card__techs{margin-top:12px}
.section--light .pf-card__tech{
  background:rgba(99,102,241,.06);
  color:#4f46e5;
  border:1px solid rgba(99,102,241,.12);
}
.section--light .pf-card__client{
  background:rgba(0,0,0,.6);color:#fff;
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);
}

/* Icon variant in light sections */
.section--light .pf-grid--icon{
  grid-template-columns:repeat(3,1fr);
}
.section--light .pf-card--icon{
  background:#fff;
  border:1px solid #e2e8f0;
  box-shadow:0 4px 20px rgba(0,0,0,.06);
}
.section--light .pf-card--icon::after{
  opacity:.03;
}
.section--light .pf-card--icon:hover{
  border-color:var(--pf-color);
  transform:translateY(-8px);
  box-shadow:0 20px 50px rgba(0,0,0,.1),0 0 30px rgba(99,102,241,.08);
  background:linear-gradient(165deg,#fff 0%,#fafbff 100%);
}
.section--light .pf-card--icon .pf-card__title{
  color:#0f172a;
}
.section--light .pf-card__client-label{
  color:var(--pf-color);
  border-bottom-color:color-mix(in srgb,var(--pf-color) 20%,transparent);
}
.section--light .pf-card--icon .pf-card__desc{
  color:#64748b;
}
.section--light .pf-card--icon .pf-card__stats{
  background:rgba(0,0,0,.015);
  border-top:1px solid #e2e8f0;
}
.section--light .pf-card--icon .pf-card__stat{
  border-right-color:rgba(0,0,0,.04);
}
.section--light .pf-card--icon .pf-card__stat-val{
  color:var(--pf-color);text-shadow:none;
}
.section--light .pf-card--icon .pf-card__stat-lbl{
  color:#94a3b8;
}
.section--light .pf-card__tag{
  background:color-mix(in srgb,var(--pf-color) 6%,transparent);
  color:var(--pf-color);
  border:1px solid color-mix(in srgb,var(--pf-color) 12%,transparent);
}
/* Link reset in light theme */
.section--light a.pf-card{color:inherit}

/* ── EMPTY STATE ──────────────────────────────────────────────── */
.pf-empty{
  text-align:center;padding:60px 20px;
  background:rgba(255,255,255,.02);border:1px dashed rgba(255,255,255,.1);
  border-radius:20px;
}
.pf-empty__icon{
  width:64px;height:64px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(99,102,241,.1);color:rgba(255,255,255,.3);
  font-size:1.5rem;margin:0 auto 16px;
}
.pf-empty__text{
  color:rgba(255,255,255,.35);font-size:.95rem;margin-bottom:20px;
}

/* ── CTA BANNER ──────────────────────────────────────────────── */
.pf-cta{
  position:relative;padding:100px 0;overflow:hidden;
  background:linear-gradient(160deg,#0c0a1a 0%,#1a1145 50%,#0f172a 100%);
  text-align:center;
}
.pf-cta__glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(99,102,241,.2),transparent 65%);
  pointer-events:none;
}
.pf-cta__inner{position:relative;z-index:1;max-width:650px;margin:0 auto}
.pf-cta__title{
  font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:800;color:#fff;margin-bottom:16px;
}
.pf-cta__desc{
  font-size:1.05rem;color:rgba(255,255,255,.5);line-height:1.7;
  margin-bottom:32px;
}
.pf-cta__actions{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
}

/* ── CONTACT SECTION (matching O nas / Oferta exactly) ────────── */
.contact__grid{
  display:grid;grid-template-columns:1.3fr .7fr;gap:48px;
  align-items:start;
}
.contact-form{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:40px 36px;
  backdrop-filter:blur(10px);
}
.contact-form__row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.contact-form__group{display:flex;flex-direction:column;gap:6px}
.contact-form__group label{font-size:.85rem;font-weight:500;color:rgba(255,255,255,.7)}
.contact-form__group label small{color:var(--gray-400)}
.contact-form__group input,
.contact-form__group textarea,
.contact-form__group select{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-sm);padding:13px 16px;font-size:.92rem;
  color:#fff;transition:all .25s;outline:none;
  font-family:var(--font);
}
.contact-form__group input::placeholder,
.contact-form__group textarea::placeholder{color:rgba(255,255,255,.3)}
.contact-form__group input:focus,
.contact-form__group textarea:focus,
.contact-form__group select:focus{
  border-color:var(--electric);
  box-shadow:0 0 0 3px rgba(99,102,241,.15);
  background:rgba(255,255,255,.08);
}
.contact-form__group select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='%2394A3B8'%3E%3Cpath d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
  padding-right:36px;
}
.contact-form__group select option{background:var(--dark-card);color:#fff}
.contact-form__error{font-size:.78rem;color:var(--rose);min-height:16px}
.contact-form__rodo{margin:16px 0 24px}
.contact-form__checkbox{display:flex;align-items:flex-start;gap:12px;cursor:pointer}
.contact-form__checkbox input[type="checkbox"]{display:none}
.contact-form__checkmark{
  width:20px;height:20px;min-width:20px;border-radius:5px;
  border:2px solid rgba(255,255,255,.2);display:flex;
  align-items:center;justify-content:center;transition:all .25s;margin-top:2px;
}
.contact-form__checkbox input:checked~.contact-form__checkmark{
  background:var(--electric);border-color:var(--electric);
}
.contact-form__checkbox input:checked~.contact-form__checkmark::after{
  content:'\2713';color:#fff;font-size:.72rem;font-weight:700;
}
.contact-form__checkbox-text{font-size:.82rem;color:rgba(255,255,255,.55);line-height:1.5}
.contact-form__checkbox-text a{color:var(--electric);text-decoration:underline}

.contact-info{display:flex;flex-direction:column;gap:18px}
.contact-info__card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-sm);padding:22px 20px;display:flex;gap:16px;align-items:flex-start;
  transition:all .3s;
}
.contact-info__card:hover{border-color:rgba(99,102,241,.2);background:rgba(99,102,241,.05)}
.contact-info__card i{font-size:1.3rem;color:var(--electric);margin-top:2px}
.contact-info__card h3{font-size:.95rem;font-weight:600;margin-bottom:4px}
.contact-info__card p{font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.5}
.contact-info__card a{color:var(--electric);text-decoration:underline}

/* ── Form toast ──────────────────────────────────────────────── */
.form-toast{
  position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);
  z-index:10000;opacity:0;visibility:hidden;pointer-events:none;
  transition:all .5s cubic-bezier(.34,1.56,.64,1);
}
.form-toast.show{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.form-toast__inner{
  display:flex;align-items:center;gap:14px;
  background:linear-gradient(135deg,var(--indigo),var(--electric));
  padding:16px 24px;border-radius:14px;color:#fff;
  box-shadow:0 10px 40px rgba(99,102,241,.4);
}
.form-toast__icon{font-size:1.4rem}
.form-toast__content strong{display:block;font-size:.95rem}
.form-toast__content p{font-size:.82rem;opacity:.8}
.form-toast__close{
  background:rgba(255,255,255,.15);border:none;color:#fff;width:30px;height:30px;
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.form-toast__close:hover{background:rgba(255,255,255,.25)}

/* ── ANIMATIONS ──────────────────────────────────────────────── */
[data-animate]{
  opacity:0;transform:translateY(24px);
  transition:opacity .7s ease,transform .7s ease;
}
[data-animate].animated,
[data-animate].visible{
  opacity:1;transform:translateY(0);
}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1024px){
  .pf-grid--image,
  .pf-grid--icon{
    grid-template-columns:repeat(2,1fr);
  }
}
@media(max-width:768px){
  .pf-hero{min-height:55vh;padding:120px 0 60px}
  .pf-hero__title{font-size:clamp(1.8rem,5vw,2.6rem)}
  :root{--section-py:80px}

  .contact__grid{grid-template-columns:1fr}
  .contact-form{padding:28px 20px}
  .contact-form__row{grid-template-columns:1fr}
  .contact-info__card{flex-direction:column}
}
@media(max-width:640px){
  .pf-hero{padding:100px 0 60px;min-height:auto}
  .pf-section{padding:60px 0 40px}
  .pf-section__header{gap:12px;margin-bottom:32px}
  .pf-section__icon{width:44px;height:44px;border-radius:12px;font-size:1rem}
  .pf-section__title{font-size:1.35rem}

  .pf-grid--image,
  .pf-grid--icon{
    grid-template-columns:1fr;
  }

  .pf-nav__pill{padding:6px 12px;font-size:.75rem}
  .pf-nav__pill span{display:none}

  .pf-cta{padding:60px 0}
  .pf-cta__actions{flex-direction:column;align-items:center}
  .pf-hero__actions{flex-direction:column;align-items:center}
}
@media(max-width:480px){
  .pf-hero{padding:110px 0 50px}
  :root{--section-py:60px}
}
