/* DeFi Cinema — high-fidelity DeFi product landing */
:root{
  --dfc-bg:#06080d;
  --dfc-bg-2:#0a0e16;
  --dfc-line:rgba(255,255,255,0.08);
  --dfc-line-2:rgba(255,255,255,0.14);
  --dfc-text:#e9eef7;
  --dfc-text-2:rgba(233,238,247,0.72);
  --dfc-text-3:rgba(233,238,247,0.48);
  --dfc-mint:#5EFFA4;
  --dfc-cyan:#4FC8FF;
  --dfc-violet:#A78BFA;
  --dfc-amber:#FFB020;
  --dfc-pink:#FF6FB5;
  --dfc-red:#FF5C7A;
}
@keyframes dfc-pulse{ 0%,100%{opacity:1;} 50%{opacity:.4;} }
@keyframes dfc-fadeup{ from{opacity:0; transform:translateY(14px);} to{opacity:1; transform:translateY(0);} }
@keyframes dfc-scan{ 0%{ top:0; opacity:0;} 10%{opacity:.7;} 90%{opacity:.7;} 100%{ top:100%; opacity:0;} }
@keyframes dfc-orbit{ from{transform:rotate(0deg);} to{transform:rotate(360deg);} }
@keyframes dfc-blink{ 50%{ opacity:.2; } }
@keyframes dfc-drift{ 0%,100%{transform:translateY(0);} 50%{transform:translateY(-6px);} }
@keyframes dfc-tickerLoop{ from{transform:translateX(0);} to{transform:translateX(-50%);} }
@keyframes dfc-shimmer{ 0%{ background-position:-200% 0;} 100%{ background-position:200% 0;} }

/* ---------- SECTION HEAD ---------- */
.dfc-section-head{ max-width:1320px; margin:0 auto; padding:96px 32px 36px; }
.dfc-eyebrow{ font:600 11px/1 ui-monospace,Menlo,monospace; letter-spacing:.18em; color:var(--dfc-mint); margin-bottom:18px; }
.dfc-h2{ font:600 56px/1.04 'Helvetica Neue',Helvetica,Arial,sans-serif; letter-spacing:-0.02em; margin:0 0 18px; text-wrap:balance; max-width:980px; color:var(--dfc-text); }
.dfc-h2 em{ font-style:normal; background:linear-gradient(100deg,var(--dfc-mint),var(--dfc-cyan)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.dfc-sub{ font:400 18px/1.55 'Helvetica Neue',Helvetica,Arial,sans-serif; color:var(--dfc-text-2); max-width:760px; text-wrap:pretty; margin:0; }

/* ---------- BUTTONS ---------- */
.dfc-btn{ display:inline-flex; align-items:center; gap:10px; padding:14px 22px; border-radius:999px; font:500 14px/1 'Helvetica Neue',Helvetica,Arial,sans-serif; text-decoration:none; transition:transform .2s, box-shadow .2s, background .2s; cursor:pointer; border:0; }
.dfc-btn-primary{ background:linear-gradient(100deg,var(--dfc-mint),#3DE695); color:#06120a; box-shadow:0 8px 28px rgba(94,255,164,.22); }
.dfc-btn-primary:hover{ transform:translateY(-1px); box-shadow:0 10px 36px rgba(94,255,164,.32); }
.dfc-btn-ghost{ background:transparent; color:var(--dfc-text); border:1px solid var(--dfc-line-2); }
.dfc-btn-ghost:hover{ background:rgba(255,255,255,.04); }
.dfc-btn span{ font-size:18px; }

/* ============================================================
   HERO — live DeFi trading desk feel
   ============================================================ */
.dfc-hero{ position:relative; overflow:hidden; padding:64px 0 48px; background:radial-gradient(ellipse 80% 60% at 20% 10%, rgba(94,255,164,.08), transparent 60%), radial-gradient(ellipse 60% 50% at 90% 80%, rgba(79,200,255,.06), transparent 60%), linear-gradient(180deg,#06080d 0%, #08111a 100%); }
.dfc-hero-grid{ position:absolute; inset:0; background-image:linear-gradient(rgba(94,255,164,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(94,255,164,.04) 1px,transparent 1px); background-size:54px 54px; mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 50%, transparent 90%); pointer-events:none; }
.dfc-hero-inner{ position:relative; max-width:1360px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:1.02fr 1.18fr; gap:56px; align-items:center; min-height:82vh; }
.dfc-hero-pill{ display:inline-flex; align-items:center; gap:10px; padding:8px 14px; border-radius:999px; background:rgba(255,255,255,.04); border:1px solid var(--dfc-line); font:600 10.5px/1 ui-monospace,Menlo,monospace; letter-spacing:.14em; color:var(--dfc-text-2); margin-bottom:24px; }
.dfc-dot{ width:7px; height:7px; border-radius:50%; background:var(--dfc-mint); box-shadow:0 0 12px var(--dfc-mint); animation:dfc-pulse 1.6s infinite; display:inline-block; }
.dfc-hero-h{ font:600 78px/1 'Helvetica Neue',Helvetica,Arial,sans-serif; letter-spacing:-0.028em; margin:0 0 26px; text-wrap:balance; color:var(--dfc-text); }
.dfc-grad{ background:linear-gradient(100deg,var(--dfc-mint),var(--dfc-cyan) 70%); -webkit-background-clip:text; background-clip:text; color:transparent; }
.dfc-grad-2{ background:linear-gradient(100deg,var(--dfc-violet),var(--dfc-pink) 70%); -webkit-background-clip:text; background-clip:text; color:transparent; }
.dfc-fade{ display:inline-block; animation:dfc-fadeup .9s cubic-bezier(.2,.7,.2,1) both; }
.dfc-fade:nth-child(2){ animation-delay:.07s; }
.dfc-fade:nth-child(3){ animation-delay:.14s; }
.dfc-hero-sub{ font:400 18px/1.5 'Helvetica Neue',Helvetica,Arial,sans-serif; color:var(--dfc-text-2); max-width:540px; margin:0 0 32px; text-wrap:pretty; }
.dfc-hero-ctas{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:34px; }
.dfc-hero-meta{ display:flex; gap:32px; flex-wrap:wrap; padding-top:24px; border-top:1px solid var(--dfc-line); }
.dfc-hero-meta-i{ display:flex; flex-direction:column; gap:6px; }
.dfc-hero-meta-v{ font:600 22px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); letter-spacing:-0.01em; }
.dfc-hero-meta-l{ font:500 10.5px/1 ui-monospace,Menlo,monospace; letter-spacing:.14em; color:var(--dfc-text-3); text-transform:uppercase; }
.dfc-hero-meta-grad{ background:linear-gradient(100deg,var(--dfc-mint),var(--dfc-cyan)); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ---- hero stage (trading desk) ---- */
.dfc-hero-stage{ position:relative; animation:dfc-fadeup .8s both; }
.dfc-desk{ position:relative; border-radius:20px; overflow:hidden; background:linear-gradient(160deg,#0c1320 0%, #050810 100%); border:1px solid var(--dfc-line-2); box-shadow:0 28px 72px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.04); }
.dfc-desk-bar{ display:flex; align-items:center; gap:8px; padding:14px 18px; border-bottom:1px solid var(--dfc-line); background:rgba(0,0,0,.3); }
.dfc-desk-dots{ display:flex; gap:6px; }
.dfc-desk-dot{ width:10px; height:10px; border-radius:50%; background:#272d3a; }
.dfc-desk-dot.r{ background:#ff5f57; }
.dfc-desk-dot.y{ background:#febc2e; }
.dfc-desk-dot.g{ background:#28c840; }
.dfc-desk-url{ margin-left:14px; font:500 11px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.04em; }
.dfc-desk-live{ margin-left:auto; display:inline-flex; align-items:center; gap:6px; padding:5px 10px; border-radius:6px; background:rgba(94,255,164,.12); color:var(--dfc-mint); font:600 9.5px/1 ui-monospace,Menlo,monospace; letter-spacing:.14em; }

.dfc-desk-body{ padding:20px; display:grid; grid-template-columns:1.4fr 1fr; gap:14px; }
.dfc-desk-panel{ border-radius:14px; padding:18px; background:rgba(255,255,255,.02); border:1px solid var(--dfc-line); position:relative; overflow:hidden; }
.dfc-desk-panel-h{ display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.dfc-desk-panel-t{ font:600 13px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); }
.dfc-desk-panel-tag{ font:600 9.5px/1 ui-monospace,Menlo,monospace; letter-spacing:.16em; color:var(--dfc-text-3); }
.dfc-desk-tvl{ font:600 44px/1 'Helvetica Neue',sans-serif; letter-spacing:-0.025em; background:linear-gradient(100deg,var(--dfc-mint),var(--dfc-cyan)); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:6px; }
.dfc-desk-tvl-d{ font:500 11px/1 ui-monospace,Menlo,monospace; color:var(--dfc-mint); letter-spacing:.06em; }

/* SVG chart container */
.dfc-chart{ position:relative; height:140px; margin-top:12px; }
.dfc-chart svg{ width:100%; height:100%; display:block; }
.dfc-chart-axis{ display:flex; justify-content:space-between; margin-top:6px; font:500 9.5px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.08em; }

/* Side pools */
.dfc-pool-list{ display:flex; flex-direction:column; gap:10px; }
.dfc-pool{ padding:12px 14px; border-radius:12px; background:rgba(255,255,255,.02); border:1px solid var(--dfc-line); transition:all .25s; cursor:default; }
.dfc-pool:hover{ background:rgba(255,255,255,.04); border-color:var(--dfc-line-2); }
.dfc-pool.live{ background:linear-gradient(100deg, rgba(94,255,164,.08), rgba(94,255,164,.02)); border-color:rgba(94,255,164,.32); }
.dfc-pool-row{ display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.dfc-pool-asset{ display:flex; align-items:center; gap:8px; font:600 13px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); }
.dfc-pool-glyph{ width:24px; height:24px; border-radius:50%; display:grid; place-items:center; font:700 10px/1 'Helvetica Neue',sans-serif; color:#06120a; }
.dfc-pool-apy{ font:600 16px/1 'Helvetica Neue',sans-serif; letter-spacing:-0.01em; }
.dfc-pool-apy.mint{ color:var(--dfc-mint); }
.dfc-pool-apy.cyan{ color:var(--dfc-cyan); }
.dfc-pool-apy.amber{ color:var(--dfc-amber); }
.dfc-pool-apy.violet{ color:var(--dfc-violet); }
.dfc-pool-bar{ height:4px; border-radius:2px; background:rgba(255,255,255,.06); overflow:hidden; margin-bottom:6px; }
.dfc-pool-bar > span{ display:block; height:100%; background:linear-gradient(90deg,var(--dfc-mint),var(--dfc-cyan)); transition:width 1.2s ease; }
.dfc-pool-foot{ display:flex; justify-content:space-between; font:500 10px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.06em; }

/* Floating chips */
.dfc-chip{ position:absolute; padding:12px 16px 14px; border-radius:12px; background:rgba(8,14,22,.92); backdrop-filter:blur(14px); border:1px solid var(--dfc-line-2); box-shadow:0 14px 38px rgba(0,0,0,.5); animation:dfc-drift 4s ease-in-out infinite; }
.dfc-chip-1{ top:-18px; left:-20px; }
.dfc-chip-2{ bottom:-18px; right:-22px; animation-delay:1.5s; }
.dfc-chip-l{ font:600 9.5px/1 ui-monospace,Menlo,monospace; letter-spacing:.16em; color:var(--dfc-text-3); margin-bottom:6px; }
.dfc-chip-v{ font:600 22px/1 'Helvetica Neue',sans-serif; color:var(--dfc-mint); letter-spacing:-0.01em; }
.dfc-chip-2 .dfc-chip-v{ color:var(--dfc-cyan); }

/* Asset ticker tape */
.dfc-tape{ position:relative; margin-top:16px; height:48px; overflow:hidden; border-radius:12px; background:rgba(0,0,0,.4); border:1px solid var(--dfc-line); }
.dfc-tape-track{ display:flex; gap:32px; padding:14px 20px; white-space:nowrap; animation:dfc-tickerLoop 36s linear infinite; width:max-content; }
.dfc-tape-i{ display:inline-flex; align-items:center; gap:8px; font:600 12px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); }
.dfc-tape-i .sym{ color:var(--dfc-text-3); font:500 11px/1 ui-monospace,Menlo,monospace; letter-spacing:.06em; }
.dfc-tape-i .up{ color:var(--dfc-mint); }
.dfc-tape-i .dn{ color:var(--dfc-red); }

@media (max-width:980px){
  .dfc-hero-inner{ grid-template-columns:1fr; gap:36px; min-height:0; }
  .dfc-hero-h{ font-size:44px; }
  .dfc-h2{ font-size:36px; }
  .dfc-desk-body{ grid-template-columns:1fr; }
}

/* ============================================================
   STRATEGIES EXPLORER — interactive tabs + stage
   ============================================================ */
.dfc-strat{ padding-bottom:96px; }
.dfc-strat-frame{ max-width:1360px; margin:0 auto; padding:0 32px; }
.dfc-strat-rail{ display:grid; grid-template-columns:repeat(6,1fr); gap:6px; margin-bottom:18px; }
.dfc-strat-tab{ display:flex; flex-direction:column; align-items:flex-start; gap:6px; padding:16px 16px; border-radius:12px; background:rgba(255,255,255,.02); border:1px solid var(--dfc-line); color:var(--dfc-text-3); cursor:pointer; text-align:left; transition:all .25s; }
.dfc-strat-tab:hover{ background:rgba(255,255,255,.04); color:var(--dfc-text); }
.dfc-strat-tab.on{ background:linear-gradient(100deg, rgba(94,255,164,.14), rgba(79,200,255,.06)); border-color:rgba(94,255,164,.42); color:var(--dfc-text); }
.dfc-strat-tab-i{ width:28px; height:28px; border-radius:8px; background:rgba(94,255,164,.12); display:grid; place-items:center; color:var(--dfc-mint); font:700 14px/1 'Helvetica Neue',sans-serif; }
.dfc-strat-tab.on .dfc-strat-tab-i{ background:rgba(94,255,164,.22); }
.dfc-strat-tab-t{ font:600 14px/1.15 'Helvetica Neue',sans-serif; letter-spacing:-0.005em; }
.dfc-strat-tab-d{ font:500 10.5px/1.3 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.06em; }

.dfc-strat-stage{ display:grid; grid-template-columns:1.05fr 1.2fr; gap:24px; border-radius:18px; overflow:hidden; background:#0b1018; border:1px solid var(--dfc-line); animation:dfc-fadeup .45s both; }
.dfc-strat-left{ padding:36px; display:flex; flex-direction:column; gap:18px; position:relative; }
.dfc-strat-left::before{ content:''; position:absolute; inset:0; background:radial-gradient(ellipse at top left, rgba(94,255,164,.06), transparent 60%); pointer-events:none; }
.dfc-strat-left > *{ position:relative; }
.dfc-strat-cat{ display:inline-flex; align-self:flex-start; gap:8px; padding:6px 12px; border-radius:999px; background:rgba(94,255,164,.1); border:1px solid rgba(94,255,164,.3); color:var(--dfc-mint); font:600 10px/1 ui-monospace,Menlo,monospace; letter-spacing:.14em; }
.dfc-strat-h{ font:600 36px/1.1 'Helvetica Neue',sans-serif; letter-spacing:-0.015em; color:var(--dfc-text); margin:0; }
.dfc-strat-d{ font:400 16px/1.55 'Helvetica Neue',sans-serif; color:var(--dfc-text-2); margin:0; text-wrap:pretty; }
.dfc-strat-feats{ display:grid; grid-template-columns:1fr 1fr; gap:10px 16px; margin-top:8px; }
.dfc-strat-feat{ display:flex; align-items:flex-start; gap:8px; font:500 13.5px/1.4 'Helvetica Neue',sans-serif; color:var(--dfc-text-2); }
.dfc-strat-feat::before{ content:''; width:6px; height:6px; border-radius:50%; background:var(--dfc-mint); margin-top:8px; flex:0 0 6px; }
.dfc-strat-stats{ display:flex; gap:24px; padding-top:18px; border-top:1px solid var(--dfc-line); margin-top:8px; }
.dfc-strat-stat-v{ font:600 24px/1 'Helvetica Neue',sans-serif; color:var(--dfc-mint); letter-spacing:-0.015em; }
.dfc-strat-stat-l{ font:500 10px/1.3 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.12em; text-transform:uppercase; margin-top:6px; }

/* Right: per-strategy mock UI */
.dfc-strat-right{ padding:24px; min-height:480px; }

@media (max-width:980px){
  .dfc-strat-rail{ grid-template-columns:repeat(3,1fr); }
  .dfc-strat-stage{ grid-template-columns:1fr; }
  .dfc-strat-h{ font-size:26px; }
}

/* ============================================================
   YIELD SIMULATOR — interactive calculator
   ============================================================ */
.dfc-sim{ padding-bottom:96px; background:linear-gradient(180deg, transparent, rgba(94,255,164,.025) 50%, transparent); }
.dfc-sim-frame{ max-width:1360px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:.85fr 1.15fr; gap:32px; align-items:stretch; }
.dfc-sim-controls{ padding:32px; border-radius:18px; background:#0b1018; border:1px solid var(--dfc-line); display:flex; flex-direction:column; gap:24px; }
.dfc-sim-ctl-l{ font:500 11px/1 ui-monospace,Menlo,monospace; letter-spacing:.14em; color:var(--dfc-text-3); text-transform:uppercase; margin-bottom:10px; }
.dfc-sim-amt{ display:flex; align-items:baseline; gap:6px; }
.dfc-sim-amt input{ flex:1; min-width:0; padding:14px 18px; border-radius:12px; background:rgba(255,255,255,.04); border:1px solid var(--dfc-line); color:var(--dfc-text); font:600 28px/1 'Helvetica Neue',sans-serif; letter-spacing:-0.01em; outline:none; transition:border-color .2s; }
.dfc-sim-amt input:focus{ border-color:var(--dfc-mint); }
.dfc-sim-cur{ font:600 14px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); }
.dfc-sim-slider{ -webkit-appearance:none; appearance:none; width:100%; height:6px; background:rgba(255,255,255,.08); border-radius:3px; outline:none; }
.dfc-sim-slider::-webkit-slider-thumb{ -webkit-appearance:none; width:20px; height:20px; border-radius:50%; background:var(--dfc-mint); cursor:pointer; border:3px solid #06080d; box-shadow:0 0 0 1px var(--dfc-mint); }
.dfc-sim-slider::-moz-range-thumb{ width:20px; height:20px; border-radius:50%; background:var(--dfc-mint); cursor:pointer; border:3px solid #06080d; }
.dfc-sim-slider-v{ font:600 22px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); margin-top:8px; letter-spacing:-0.01em; }
.dfc-sim-slider-v span{ font:500 13px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); margin-left:6px; }
.dfc-sim-strats{ display:grid; grid-template-columns:repeat(2,1fr); gap:8px; }
.dfc-sim-strat{ padding:12px 14px; border-radius:10px; background:rgba(255,255,255,.02); border:1px solid var(--dfc-line); color:var(--dfc-text-2); font:500 12.5px/1.2 'Helvetica Neue',sans-serif; cursor:pointer; text-align:left; transition:all .2s; display:flex; flex-direction:column; gap:4px; }
.dfc-sim-strat:hover{ background:rgba(255,255,255,.04); color:var(--dfc-text); }
.dfc-sim-strat.on{ background:linear-gradient(100deg, rgba(94,255,164,.16), rgba(79,200,255,.04)); border-color:rgba(94,255,164,.4); color:var(--dfc-text); }
.dfc-sim-strat-apy{ font:600 16px/1 'Helvetica Neue',sans-serif; color:var(--dfc-mint); letter-spacing:-0.01em; }

.dfc-sim-result{ padding:32px; border-radius:18px; background:linear-gradient(160deg,#0e1422,#070a12); border:1px solid var(--dfc-line-2); position:relative; overflow:hidden; }
.dfc-sim-result::before{ content:''; position:absolute; inset:0; background:radial-gradient(ellipse at top right, rgba(94,255,164,.1), transparent 60%); pointer-events:none; }
.dfc-sim-result > *{ position:relative; }
.dfc-sim-r-l{ font:500 11px/1 ui-monospace,Menlo,monospace; letter-spacing:.16em; color:var(--dfc-text-3); text-transform:uppercase; margin-bottom:10px; }
.dfc-sim-r-v{ font:600 64px/1 'Helvetica Neue',sans-serif; letter-spacing:-0.025em; background:linear-gradient(100deg,var(--dfc-mint),var(--dfc-cyan)); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:6px; }
.dfc-sim-r-d{ font:500 13px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-2); letter-spacing:.04em; margin-bottom:24px; }
.dfc-sim-r-chart{ height:220px; margin-bottom:18px; }
.dfc-sim-r-chart svg{ width:100%; height:100%; display:block; }
.dfc-sim-r-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; padding-top:18px; border-top:1px solid var(--dfc-line); }
.dfc-sim-r-i-l{ font:500 10px/1.2 ui-monospace,Menlo,monospace; letter-spacing:.12em; color:var(--dfc-text-3); text-transform:uppercase; margin-bottom:6px; }
.dfc-sim-r-i-v{ font:600 18px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); letter-spacing:-0.01em; }

@media (max-width:980px){ .dfc-sim-frame{ grid-template-columns:1fr; } .dfc-sim-r-v{ font-size:44px; } }

/* ============================================================
   PORTFOLIO UI — mobile + desktop mockups
   ============================================================ */
.dfc-port{ padding-bottom:96px; }
.dfc-port-frame{ max-width:1360px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:.8fr 1.2fr; gap:48px; align-items:center; }
.dfc-port-info{ display:flex; flex-direction:column; gap:18px; }
.dfc-port-features{ display:flex; flex-direction:column; gap:14px; margin-top:8px; }
.dfc-port-feat{ display:flex; gap:14px; align-items:flex-start; padding:18px; border-radius:14px; background:#0b1018; border:1px solid var(--dfc-line); transition:all .25s; }
.dfc-port-feat:hover{ border-color:var(--dfc-line-2); background:#0d121c; }
.dfc-port-feat-i{ width:36px; height:36px; border-radius:10px; background:rgba(94,255,164,.12); color:var(--dfc-mint); display:grid; place-items:center; font:700 16px/1 'Helvetica Neue',sans-serif; flex:0 0 36px; }
.dfc-port-feat-t{ font:600 16px/1.2 'Helvetica Neue',sans-serif; color:var(--dfc-text); margin-bottom:5px; }
.dfc-port-feat-d{ font:400 13.5px/1.45 'Helvetica Neue',sans-serif; color:var(--dfc-text-2); }

/* phone mockup */
.dfc-phone-wrap{ position:relative; display:flex; justify-content:center; align-items:center; min-height:680px; }
.dfc-phone-bg{ position:absolute; inset:0; background:radial-gradient(ellipse at center, rgba(94,255,164,.08), transparent 60%); }
.dfc-phone{ position:relative; width:320px; height:660px; border-radius:48px; background:linear-gradient(160deg,#0e1622,#06080d); border:1px solid var(--dfc-line-2); box-shadow:0 28px 80px rgba(0,0,0,.55), 0 0 0 8px #050810, 0 0 0 9px #1a2030; padding:18px; }
.dfc-phone-notch{ position:absolute; top:22px; left:50%; transform:translateX(-50%); width:96px; height:26px; border-radius:14px; background:#000; z-index:2; }
.dfc-phone-screen{ width:100%; height:100%; border-radius:32px; background:linear-gradient(180deg,#08111e,#06080d); overflow:hidden; padding:48px 14px 18px; position:relative; }
.dfc-phone-top{ display:flex; justify-content:space-between; padding:0 8px 14px; font:600 11px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-2); }
.dfc-phone-head{ padding:0 6px 12px; }
.dfc-phone-greet{ font:500 11px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.1em; margin-bottom:6px; }
.dfc-phone-bal{ font:600 32px/1 'Helvetica Neue',sans-serif; letter-spacing:-0.02em; color:var(--dfc-text); }
.dfc-phone-bal-d{ font:500 11px/1 ui-monospace,Menlo,monospace; color:var(--dfc-mint); letter-spacing:.06em; margin-top:4px; }
.dfc-phone-actions{ display:grid; grid-template-columns:repeat(4,1fr); gap:6px; padding:10px 0 14px; }
.dfc-phone-act{ aspect-ratio:1; border-radius:12px; background:rgba(255,255,255,.04); border:1px solid var(--dfc-line); display:grid; place-items:center; font:700 16px/1 'Helvetica Neue',sans-serif; color:var(--dfc-mint); }
.dfc-phone-act-l{ font:500 9px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.04em; text-align:center; margin-top:6px; }
.dfc-phone-section-h{ display:flex; justify-content:space-between; padding:10px 6px 8px; font:600 12px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); }
.dfc-phone-section-h span{ font:500 10px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.06em; }
.dfc-phone-pos{ padding:11px 12px; border-radius:11px; background:rgba(255,255,255,.025); border:1px solid var(--dfc-line); margin-bottom:6px; display:flex; align-items:center; gap:10px; }
.dfc-phone-pos-i{ width:28px; height:28px; border-radius:50%; display:grid; place-items:center; font:700 11px/1 'Helvetica Neue',sans-serif; color:#06120a; flex:0 0 28px; }
.dfc-phone-pos-info{ flex:1; min-width:0; }
.dfc-phone-pos-n{ font:600 12px/1.15 'Helvetica Neue',sans-serif; color:var(--dfc-text); }
.dfc-phone-pos-d{ font:500 9.5px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); margin-top:3px; letter-spacing:.04em; }
.dfc-phone-pos-r{ text-align:right; }
.dfc-phone-pos-v{ font:600 12px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); }
.dfc-phone-pos-y{ font:500 10px/1 ui-monospace,Menlo,monospace; color:var(--dfc-mint); margin-top:3px; }

/* phone floating chip */
.dfc-phone-float{ position:absolute; padding:12px 16px; border-radius:14px; background:rgba(8,14,22,.94); backdrop-filter:blur(14px); border:1px solid var(--dfc-line-2); box-shadow:0 14px 38px rgba(0,0,0,.55); animation:dfc-drift 4s ease-in-out infinite; }
.dfc-phone-float-1{ right:-30px; top:80px; }
.dfc-phone-float-2{ left:-30px; bottom:120px; animation-delay:1.6s; }

@media (max-width:980px){ .dfc-port-frame{ grid-template-columns:1fr; } }

/* ============================================================
   PROTOCOL HEATMAP — visual liquidity data
   ============================================================ */
.dfc-heat{ padding-bottom:96px; }
.dfc-heat-frame{ max-width:1360px; margin:0 auto; padding:0 32px; }
.dfc-heat-card{ border-radius:18px; background:#0b1018; border:1px solid var(--dfc-line); overflow:hidden; }
.dfc-heat-bar{ display:flex; align-items:center; justify-content:space-between; padding:18px 24px; border-bottom:1px solid var(--dfc-line); background:rgba(0,0,0,.25); }
.dfc-heat-bar-l{ font:600 13px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); display:flex; align-items:center; gap:10px; }
.dfc-heat-filters{ display:flex; gap:6px; }
.dfc-heat-f{ padding:7px 12px; border-radius:7px; background:transparent; border:1px solid var(--dfc-line); color:var(--dfc-text-3); font:500 11px/1 'Helvetica Neue',sans-serif; cursor:pointer; transition:all .2s; }
.dfc-heat-f:hover{ color:var(--dfc-text); }
.dfc-heat-f.on{ background:rgba(94,255,164,.12); border-color:rgba(94,255,164,.34); color:var(--dfc-mint); }
.dfc-heat-grid{ display:grid; grid-template-columns:repeat(18,1fr); gap:4px; padding:24px; }
.dfc-heat-cell{ aspect-ratio:1; border-radius:4px; background:rgba(94,255,164,.08); transition:all .25s; cursor:default; position:relative; }
.dfc-heat-cell:hover{ transform:scale(1.4); z-index:2; box-shadow:0 6px 14px rgba(0,0,0,.4); }
.dfc-heat-foot{ display:flex; justify-content:space-between; padding:18px 24px; border-top:1px solid var(--dfc-line); align-items:center; }
.dfc-heat-legend{ display:flex; gap:6px; align-items:center; font:500 11px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.06em; }
.dfc-heat-legend-bar{ width:140px; height:8px; border-radius:3px; background:linear-gradient(90deg, rgba(94,255,164,.08), var(--dfc-mint)); }
.dfc-heat-bigs{ display:flex; gap:32px; }
.dfc-heat-big-v{ font:600 22px/1 'Helvetica Neue',sans-serif; color:var(--dfc-text); letter-spacing:-0.01em; }
.dfc-heat-big-l{ font:500 10px/1 ui-monospace,Menlo,monospace; color:var(--dfc-text-3); letter-spacing:.12em; margin-top:5px; }

/* ============================================================
   USE CASES (gallery)
   ============================================================ */
.dfc-uc{ padding-bottom:96px; }
.dfc-uc-grid{ max-width:1360px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.dfc-uc-card{ display:flex; flex-direction:column; border-radius:18px; overflow:hidden; background:#0b1018; border:1px solid var(--dfc-line); transition:all .3s; cursor:default; }
.dfc-uc-card:hover{ transform:translateY(-4px); border-color:var(--dfc-line-2); box-shadow:0 18px 48px rgba(0,0,0,.4); }
.dfc-uc-img{ position:relative; aspect-ratio:16/9; overflow:hidden; }
.dfc-uc-img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.dfc-uc-card:hover .dfc-uc-img img{ transform:scale(1.06); }
.dfc-uc-img::after{ content:''; position:absolute; inset:0; background:linear-gradient(180deg,transparent 50%, rgba(11,16,24,.92)); }
.dfc-uc-cat{ position:absolute; top:12px; left:12px; z-index:2; padding:5px 10px; border-radius:999px; background:rgba(0,0,0,.55); backdrop-filter:blur(8px); border:1px solid var(--dfc-line); font:600 9.5px/1 ui-monospace,Menlo,monospace; letter-spacing:.16em; color:var(--dfc-mint); }
.dfc-uc-body{ padding:20px 22px 22px; display:flex; flex-direction:column; gap:12px; flex:1; }
.dfc-uc-t{ font:600 20px/1.18 'Helvetica Neue',sans-serif; letter-spacing:-0.01em; margin:0; color:var(--dfc-text); }
.dfc-uc-d{ font:400 14px/1.5 'Helvetica Neue',sans-serif; color:var(--dfc-text-2); margin:0; flex:1; }
.dfc-uc-metrics{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; padding-top:14px; border-top:1px solid var(--dfc-line); }
.dfc-uc-mv{ font:600 16px/1 'Helvetica Neue',sans-serif; color:var(--dfc-mint); letter-spacing:-0.01em; }
.dfc-uc-ml{ font:500 9.5px/1.2 ui-monospace,Menlo,monospace; letter-spacing:.06em; color:var(--dfc-text-3); text-transform:uppercase; margin-top:5px; }
@media (max-width:980px){ .dfc-uc-grid{ grid-template-columns:1fr; } }

/* ============================================================
   PROOF + FINAL
   ============================================================ */
.dfc-proof{ padding:0 0 96px; }
.dfc-proof-grid{ max-width:1320px; margin:0 auto; padding:36px 32px; display:grid; grid-template-columns:repeat(6,1fr); border-top:1px solid var(--dfc-line); border-bottom:1px solid var(--dfc-line); }
.dfc-proof-item{ padding:12px 18px; border-right:1px solid var(--dfc-line); }
.dfc-proof-item:last-child{ border-right:0; }
.dfc-proof-v{ font:600 32px/1 'Helvetica Neue',sans-serif; letter-spacing:-0.02em; background:linear-gradient(100deg,var(--dfc-mint),var(--dfc-cyan)); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:6px; }
.dfc-proof-l{ font:500 11px/1.3 ui-monospace,Menlo,monospace; letter-spacing:.06em; color:var(--dfc-text-3); text-transform:uppercase; }
@media (max-width:980px){ .dfc-proof-grid{ grid-template-columns:repeat(2,1fr); } .dfc-proof-item{ border-right:0; } }

.dfc-final{ position:relative; min-height:520px; padding:120px 0; overflow:hidden; }
.dfc-final-img{ position:absolute; inset:0; }
.dfc-final-img img{ width:100%; height:100%; object-fit:cover; filter:saturate(.85) brightness(.5); }
.dfc-final-img::after{ content:''; position:absolute; inset:0; background:linear-gradient(180deg, rgba(6,8,13,.55) 0%, rgba(6,8,13,.95) 100%); }
.dfc-final-inner{ position:relative; max-width:1320px; margin:0 auto; padding:0 32px; z-index:2; }
.dfc-final .dfc-h2{ font-size:60px; max-width:880px; }
.dfc-final .dfc-sub{ font-size:19px; max-width:680px; margin-bottom:32px; }
@media (max-width:980px){ .dfc-final .dfc-h2{ font-size:36px; } }
