/* ================================================
   FINSWEET — Shared Styles (Bootstrap 5 Edition)
   ================================================ */

/* ── TOKENS ─────────────────────────── */
:root {
  --navy:#0f1035; --indigo:#1c1e53; --blue-v:#2405f2;
  --gold:#fcd980; --gold-lt:#fde4a6; --offwhite:#f4f6fc;
  --slate:#eef3fb; --ink:#0a0a1a; --muted:#6b7280;
  --spring:cubic-bezier(0.34,1.56,0.64,1);
  --smooth:cubic-bezier(0.4,0,0.2,1);
  --expo:cubic-bezier(0.16,1,0.3,1);
  --shadow-card:0 4px 24px rgba(28,30,83,.08),0 1px 4px rgba(28,30,83,.05);
  --shadow-lift:0 16px 48px rgba(28,30,83,.13),0 4px 12px rgba(28,30,83,.07);
}

/* ── BASE ───────────────────────────── */
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--ink);overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:'Syne',sans-serif;font-weight:700;letter-spacing:-.025em}
a{text-decoration:none}
img{max-width:100%}

/* ── NAVBAR ─────────────────────────── */
.main-nav{background:rgba(15,16,53,.96)!important;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.07);padding:.85rem 0}
.main-nav .nav-link{font-family:'Syne',sans-serif;font-size:.875rem;font-weight:500;color:rgba(255,255,255,.72)!important;padding:.45rem .9rem!important;border-radius:8px;position:relative;transition:all 220ms var(--smooth)}
.main-nav .nav-link::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%) scaleX(0);width:14px;height:2px;background:var(--gold);border-radius:2px;transition:transform 220ms var(--spring)}
.main-nav .nav-link:hover,.main-nav .nav-link.active{color:#fff!important;background:rgba(255,255,255,.08)}
.main-nav .nav-link:hover::after,.main-nav .nav-link.active::after{transform:translateX(-50%) scaleX(1)}
.btn-contact{font-family:'Syne',sans-serif;font-size:.825rem;font-weight:600;letter-spacing:.05em;padding:.5rem 1.35rem;border-radius:8px;border:1.5px solid rgba(255,255,255,.3);color:#fff!important;background:transparent;transition:all 220ms var(--smooth);display:inline-block}
.btn-contact:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)!important;box-shadow:0 4px 20px rgba(252,217,128,.35);transform:translateY(-1px)}
.navbar-toggler{border:none}
.navbar-toggler:focus{box-shadow:none}

/* ── PAGE HERO (inner pages) ─────────── */
.page-hero{background:linear-gradient(135deg,#080a2a 0%,#0f1035 45%,#1c1e53 80%,#1a1f6e 100%);position:relative;overflow:hidden;padding:6rem 0 5rem}
.page-hero::before{content:'';position:absolute;top:-30%;right:-8%;width:600px;height:600px;background:radial-gradient(circle,rgba(36,5,242,.2) 0%,transparent 65%);animation:blob 8s ease-in-out infinite;pointer-events:none}
.page-hero::after{content:'';position:absolute;bottom:-30%;left:-5%;width:400px;height:400px;background:radial-gradient(circle,rgba(252,217,128,.09) 0%,transparent 65%);animation:blob 11s ease-in-out infinite 2s;pointer-events:none}
@keyframes blob{0%,100%{transform:scale(1) translate(0,0)}33%{transform:scale(1.08) translate(2%,-2%)}66%{transform:scale(.93) translate(-2%,3%)}}
.page-hero-title{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:800;line-height:1.1;letter-spacing:-.04em;background:linear-gradient(140deg,#fff 55%,rgba(252,217,128,.88) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.page-hero-img{filter:drop-shadow(0 24px 48px rgba(36,5,242,.25));animation:floatY 5s ease-in-out infinite}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ── COMMON COMPONENTS ───────────────── */
.eyebrow{font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-v);display:flex;align-items:center;gap:.5rem}
.eyebrow::before{content:'';width:22px;height:2px;background:var(--blue-v);border-radius:2px;flex-shrink:0}
.section-title{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;letter-spacing:-.035em;color:var(--ink)}
.link-arrow{font-family:'Syne',sans-serif;font-weight:700;font-size:.9rem;color:var(--blue-v);display:inline-flex;align-items:center;gap:.45rem;transition:gap 250ms var(--spring)}
.link-arrow:hover{gap:.75rem;color:var(--blue-v)}
.view-more-btn{font-family:'Syne',sans-serif;font-weight:700;font-size:.875rem;color:var(--ink);border:1.5px solid rgba(28,30,83,.18);border-radius:100px;padding:.55rem 1.3rem;display:inline-flex;align-items:center;gap:.45rem;transition:all 230ms var(--smooth)}
.view-more-btn:hover{background:var(--ink);color:#fff;gap:.7rem}
.btn-gold{font-family:'Syne',sans-serif;font-weight:700;font-size:.9rem;letter-spacing:.04em;padding:.85rem 2rem;border-radius:12px;background:var(--gold);color:var(--ink)!important;border:none;transition:all 280ms var(--spring);box-shadow:0 4px 20px rgba(252,217,128,.4);display:inline-block}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-3px) scale(1.02);box-shadow:0 12px 32px rgba(252,217,128,.45)}
.btn-dark{font-family:'Syne',sans-serif;font-weight:700;font-size:.875rem;padding:.8rem 1.8rem;border-radius:12px;background:#0f1035;color:#fff!important;border:none;transition:all 260ms var(--spring);display:inline-block}
.btn-dark:hover{background:#2405f2;transform:translateY(-2px);box-shadow:0 8px 24px rgba(36,5,242,.25)}
.divider{border:none;border-top:1px solid rgba(28,30,83,.1);margin:0}

/* ── BENEFIT CARDS ───────────────────── */
.benefit-card{background:#fff;border-radius:20px;border:1px solid rgba(28,30,83,.07);padding:2rem 1.75rem;height:100%;display:flex;flex-direction:column;gap:1rem;transition:all 320ms var(--expo);position:relative;overflow:hidden}
.benefit-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-v),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform 300ms var(--spring)}
.benefit-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lift)}
.benefit-card:hover::after{transform:scaleX(1)}

/* ── FAQ ─────────────────────────────── */
.faq-item{background:#fff;border-radius:14px;border:1px solid rgba(28,30,83,.08);padding:1.4rem 1.6rem;display:flex;align-items:flex-start;gap:1.1rem;transition:all 230ms var(--smooth);cursor:pointer}
.faq-item:hover{border-color:rgba(36,5,242,.14);box-shadow:var(--shadow-card);transform:translateX(4px)}
.faq-num{font-family:'Syne',sans-serif;font-size:.68rem;font-weight:800;color:var(--blue-v);background:rgba(36,5,242,.08);padding:.3rem .55rem;border-radius:6px;letter-spacing:.05em;white-space:nowrap;flex-shrink:0;margin-top:2px}
.faq-q{font-family:'Syne',sans-serif;font-size:1rem;font-weight:600;color:var(--ink);flex:1;margin:0}
.faq-answer{font-family:'DM Sans',sans-serif;font-size:.875rem;color:var(--muted);line-height:1.7;margin-top:.5rem;font-weight:400}
.faq-toggle{width:28px;height:28px;border-radius:50%;background:var(--offwhite);border:1px solid rgba(28,30,83,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 250ms var(--spring)}
.faq-toggle:hover{background:var(--blue-v);border-color:var(--blue-v)}
.faq-toggle:hover img{filter:invert(1)}
.faq-toggle img{width:14px}

/* ── PRICING CARDS ───────────────────── */
.pricing-card{background:#fff;border-radius:24px;border:1px solid rgba(28,30,83,.08);padding:2.5rem 2rem;height:100%;display:flex;flex-direction:column;gap:1.5rem;transition:all 320ms var(--expo)}
.pricing-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-lift)}
.pricing-card.featured{background:var(--indigo);color:#fff}
.pricing-card.featured:hover{background:#141650;box-shadow:0 24px 60px rgba(28,30,83,.35),0 8px 24px rgba(36,5,242,.2)}
.price-num{font-family:'Syne',sans-serif;font-size:2.5rem;font-weight:800;letter-spacing:-.04em}
.price-per{font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.plan-name{font-size:1.35rem;font-weight:800}
.feat-list-item{display:flex;align-items:center;gap:.75rem;font-size:.9rem;line-height:1.5}
.feat-list-item img{width:18px;flex-shrink:0}

/* ── BLOG CARDS ──────────────────────── */
.blog-card{background:#fff;border-radius:20px;overflow:hidden;border:1px solid rgba(28,30,83,.07);display:flex;flex-direction:column;height:100%;transition:all 320ms var(--expo)}
.blog-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lift)}
.blog-card .card-img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform 500ms var(--expo)}
.blog-card:hover .card-img{transform:scale(1.04)}
.card-body-inner{padding:1.5rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.blog-date{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-v)}
.blog-title{font-family:'Syne',sans-serif;font-size:.975rem;font-weight:700;color:var(--ink);line-height:1.4;margin:0}
.blog-excerpt{font-size:.85rem;color:var(--muted);line-height:1.6;margin:0;flex:1}
.blog-link{font-family:'Syne',sans-serif;font-weight:700;font-size:.825rem;color:var(--ink);display:inline-flex;align-items:center;gap:.4rem;transition:gap 220ms var(--spring),color 220ms}
.blog-link:hover{gap:.65rem;color:var(--blue-v)}

/* ── PORTFOLIO CARDS ─────────────────── */
.portfolio-card{border-radius:20px;overflow:hidden;border:1px solid rgba(28,30,83,.07);transition:all 320ms var(--expo)}
.portfolio-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift)}
.portfolio-card img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform 500ms var(--expo);display:block}
.portfolio-card:hover img{transform:scale(1.04)}
.portfolio-body{padding:1.5rem}
.portfolio-title{font-family:'Syne',sans-serif;font-size:1.3rem;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:.5rem}
.portfolio-desc{font-size:.875rem;color:var(--muted);line-height:1.6;margin-bottom:1rem}
.portfolio-link{font-family:'Syne',sans-serif;font-weight:700;font-size:.825rem;color:var(--ink);display:inline-flex;align-items:center;gap:.4rem;transition:gap 220ms var(--spring),color 220ms}
.portfolio-link:hover{gap:.65rem;color:var(--blue-v)}

/* ── TEAM CARDS ──────────────────────── */
.team-card{background:#fff;border-radius:20px;overflow:hidden;border:1px solid rgba(28,30,83,.07);text-align:center;padding-bottom:1.5rem;transition:all 320ms var(--expo)}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift)}
.team-card img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top;transition:transform 500ms var(--expo)}
.team-card:hover img{transform:scale(1.03)}
.team-name{font-family:'Syne',sans-serif;font-size:1.15rem;font-weight:700;color:var(--ink);margin:1rem 0 .2rem}
.team-role{font-size:.82rem;color:var(--muted)}

/* ── PROCESS STEPS ───────────────────── */
.step-card{display:flex;flex-direction:column;gap:.75rem;padding:1.75rem;background:#fff;border-radius:20px;border:1px solid rgba(28,30,83,.07);height:100%;transition:all 300ms var(--expo)}
.step-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lift);border-color:rgba(36,5,242,.1)}

/* ── CONTENT SECTIONS ────────────────── */
.content-img{border-radius:20px;width:100%;object-fit:cover;display:block}
.content-eyebrow{font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-v);margin-bottom:.75rem}

/* ── CONTACT FORM ────────────────────── */
.contact-card{background:var(--offwhite);border-radius:24px;padding:2.5rem}
.form-label-custom{font-family:'Syne',sans-serif;font-weight:600;font-size:.875rem;color:var(--ink);margin-bottom:.5rem;display:block}
.form-input-custom{background:#fff;border:1.5px solid rgba(28,30,83,.12);border-radius:12px;padding:.875rem 1.1rem;font-family:'DM Sans',sans-serif;font-size:.9rem;color:var(--ink);width:100%;outline:none;transition:all 220ms var(--smooth)}
.form-input-custom::placeholder{color:var(--muted)}
.form-input-custom:focus{border-color:var(--blue-v);box-shadow:0 0 0 3px rgba(36,5,242,.08)}
.form-textarea{resize:none;min-height:130px}

/* ── PRIVACY / ARTICLE ───────────────── */
.article-body h2{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;margin-top:2.5rem;margin-bottom:1rem;color:var(--ink)}
.article-body p{font-size:.975rem;line-height:1.8;color:#3a3a5c;margin-bottom:1.25rem}
.article-body a{color:var(--blue-v);font-weight:500}
.article-body a:hover{text-decoration:underline}
.article-body ul{padding-left:1.5rem;margin-bottom:1.25rem}
.article-body li{font-size:.975rem;line-height:1.8;color:#3a3a5c;margin-bottom:.5rem}

/* ── READ BLOG / CASE STUDY ──────────── */
.post-hero-img{width:100%;border-radius:20px;object-fit:cover;max-height:500px}
.post-body h2{font-size:clamp(1.4rem,2.5vw,1.9rem);font-weight:700;margin-top:2rem;margin-bottom:.75rem;color:var(--ink)}
.post-body p{font-size:.975rem;line-height:1.8;color:#3a3a5c;margin-bottom:1.25rem}
.post-body a{color:var(--blue-v);font-weight:500}
.post-body a:hover{text-decoration:underline}
.post-body ul{padding-left:1.5rem;margin-bottom:1.25rem}
.post-body li{font-size:.975rem;line-height:1.8;color:#3a3a5c;margin-bottom:.5rem}
.tag-pill{font-family:'Syne',sans-serif;font-size:.75rem;font-weight:700;padding:.35rem .9rem;border-radius:100px;border:1.5px solid rgba(28,30,83,.15);color:var(--muted);transition:all 200ms var(--smooth)}
.tag-pill:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ── FOOTER ──────────────────────────── */
.site-footer{background:linear-gradient(160deg,#080a2a 0%,var(--navy) 50%,var(--indigo) 100%);color:#fff;position:relative;overflow:hidden}
.site-footer::before{content:'';position:absolute;top:-40%;right:-8%;width:560px;height:560px;background:radial-gradient(circle,rgba(36,5,242,.1) 0%,transparent 65%);pointer-events:none}
.footer-desc{font-size:.875rem;color:rgba(255,255,255,.52);line-height:1.75}
.footer-contact-pill{background:var(--gold);color:var(--ink);border-radius:16px;padding:1.1rem 1.5rem;display:inline-flex;flex-wrap:wrap;gap:2rem}
.pill-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.6;margin-bottom:.15rem}
.pill-value{font-family:'Syne',sans-serif;font-weight:700;font-size:.875rem}
.footer-talk-title{font-size:clamp(2rem,4vw,3rem);font-weight:800;letter-spacing:-.04em;line-height:1.1}
.footer-talk-desc{font-size:.875rem;color:rgba(255,255,255,.52);max-width:340px;line-height:1.7}
.social-icon{width:40px;height:40px;border-radius:50%;border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:.95rem;transition:all 220ms var(--smooth)}
.social-icon:hover{border-color:var(--gold);color:var(--gold);background:rgba(252,217,128,.1);transform:translateY(-2px)}
.footer-divider{border-color:rgba(255,255,255,.08)!important}
.footer-copy{font-size:.78rem;color:rgba(255,255,255,.32)}
.footer-link{font-size:.825rem;font-weight:500;color:rgba(255,255,255,.48);transition:color 200ms;position:relative}
.footer-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;background:var(--gold);transition:width 220ms var(--spring)}
.footer-link:hover{color:#fff}
.footer-link:hover::after{width:100%}

/* ── PARTNER LOGOS ───────────────────── */
.partner-logo{height:26px;width:auto;object-fit:contain;filter:grayscale(100%) opacity(.4);transition:filter 250ms var(--smooth)}
.partner-logo:hover{filter:grayscale(0%) opacity(1)}
