/* cFox homepage — fox-ember dark theme. Served from uploads/cfox-home, enqueued by novamira-sandbox/cfox-home-loader.php */

.cfx-home-main{
  --cfx-bg:#0c0a08;
  --cfx-bg2:#131008;
  --cfx-surface:rgba(255,255,255,.035);
  --cfx-border:rgba(255,255,255,.09);
  --cfx-text:#f5efe8;
  --cfx-muted:#a89e92;
  --cfx-orange:#ff6b2c;
  --cfx-amber:#ffa94d;
  --cfx-ember:#ff4524;
  --cfx-grad:linear-gradient(96deg,#ffb45e,#ff6b2c 48%,#ff4524);
  --cfx-font:'Space Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--cfx-bg);
  color:var(--cfx-text);
  font-family:var(--cfx-font);
  overflow-x:hidden;
}
.cfx-home-main *,.cfx-home-main *::before,.cfx-home-main *::after{box-sizing:border-box}
.cfx-home-main h1,.cfx-home-main h2,.cfx-home-main h3,.cfx-home-main p,.cfx-home-main a,.cfx-home-main span,.cfx-home-main button,.cfx-home-main input{font-family:var(--cfx-font)}
.cfx-home-main a{text-decoration:none}
.cfx-wrap{max-width:1180px;margin:0 auto;padding:0 24px}

/* ---------- hero ---------- */
.cfx-hero{position:relative;min-height:92vh;display:grid;place-items:center;overflow:hidden;padding:120px 0 90px;background:radial-gradient(ellipse 120% 70% at 50% -10%,#1d1310 0%,var(--cfx-bg) 60%)}
.cfx-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:72px 72px;mask-image:radial-gradient(ellipse 80% 65% at 50% 40%,#000 0%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 80% 65% at 50% 40%,#000 0%,transparent 75%);pointer-events:none}
.cfx-aurora{position:absolute;border-radius:50%;filter:blur(95px);opacity:.32;pointer-events:none;will-change:transform}
.cfx-aurora.a1{width:560px;height:560px;left:-140px;top:-120px;background:radial-gradient(circle,#ff6b2c,transparent 68%);animation:cfxDrift1 22s ease-in-out infinite alternate}
.cfx-aurora.a2{width:480px;height:480px;right:-120px;top:18%;background:radial-gradient(circle,#ff4524,transparent 66%);opacity:.22;animation:cfxDrift2 27s ease-in-out infinite alternate}
.cfx-aurora.a3{width:520px;height:520px;left:32%;bottom:-260px;background:radial-gradient(circle,#3b2a66,transparent 70%);opacity:.4;animation:cfxDrift3 31s ease-in-out infinite alternate}
@keyframes cfxDrift1{to{transform:translate(120px,90px) scale(1.18)}}
@keyframes cfxDrift2{to{transform:translate(-100px,70px) scale(.88)}}
@keyframes cfxDrift3{to{transform:translate(-80px,-90px) scale(1.12)}}
#cfx-embers{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.cfx-hero-inner{position:relative;text-align:center;max-width:900px;padding:0 24px;z-index:2}
.cfx-eyebrow{display:inline-flex;align-items:center;gap:14px;font-size:.72rem;font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:var(--cfx-amber)}
.cfx-eyebrow::before,.cfx-eyebrow::after{content:"";width:34px;height:1px;background:linear-gradient(90deg,transparent,var(--cfx-amber));opacity:.6}
.cfx-eyebrow::after{background:linear-gradient(90deg,var(--cfx-amber),transparent)}
.cfx-h1{margin:26px 0 22px;font-size:clamp(2.7rem,6.6vw,4.9rem);line-height:1.04;font-weight:700;letter-spacing:-.02em;color:var(--cfx-text)}
.cfx-grad-text{background:var(--cfx-grad);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.cfx-sub{margin:0 auto;max-width:600px;font-size:1.08rem;line-height:1.65;color:var(--cfx-muted);font-weight:400}
.cfx-cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:38px}
.cfx-btn{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:999px;font-family:var(--cfx-font);font-size:.95rem;font-weight:700;letter-spacing:.01em;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease,background .3s ease;cursor:pointer}
.cfx-btn svg{transition:transform .3s ease}
.cfx-btn:hover svg{transform:translateX(4px)}
.cfx-btn-primary{background:var(--cfx-grad);color:#1a0d04;box-shadow:0 10px 34px rgba(255,107,44,.32)}
.cfx-btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 44px rgba(255,107,44,.45);color:#1a0d04}
.cfx-btn-ghost{border:1px solid rgba(255,255,255,.2);color:var(--cfx-text);background:rgba(255,255,255,.04);backdrop-filter:blur(8px)}
.cfx-btn-ghost:hover{border-color:rgba(255,138,61,.65);color:var(--cfx-amber);transform:translateY(-2px)}
.cfx-hero-meta{margin-top:34px;display:inline-flex;align-items:center;gap:10px;font-size:.82rem;color:var(--cfx-muted);letter-spacing:.04em}
.cfx-live-dot{width:8px;height:8px;border-radius:50%;background:#3ddc84;box-shadow:0 0 0 0 rgba(61,220,132,.5);animation:cfxPulse 2.4s ease-out infinite}
@keyframes cfxPulse{0%{box-shadow:0 0 0 0 rgba(61,220,132,.5)}70%{box-shadow:0 0 0 9px rgba(61,220,132,0)}100%{box-shadow:0 0 0 0 rgba(61,220,132,0)}}
.cfx-scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);width:24px;height:38px;border:1.5px solid rgba(255,255,255,.25);border-radius:14px;z-index:2}
.cfx-scroll::before{content:"";position:absolute;left:50%;top:7px;width:3px;height:8px;margin-left:-1.5px;border-radius:3px;background:var(--cfx-amber);animation:cfxScroll 2s ease-in-out infinite}
@keyframes cfxScroll{0%{transform:translateY(0);opacity:1}70%{transform:translateY(12px);opacity:0}100%{transform:translateY(0);opacity:0}}

/* ---------- sections ---------- */
.cfx-section{padding:104px 0;position:relative}
.cfx-section-alt{background:linear-gradient(180deg,var(--cfx-bg) 0%,#100d12 55%,var(--cfx-bg) 100%)}
.cfx-sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:52px}
.cfx-sec-head h2{margin:14px 0 10px;font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:700;letter-spacing:-.015em;line-height:1.1;color:var(--cfx-text)}
.cfx-sec-head .cfx-lede{margin:0;max-width:520px;color:var(--cfx-muted);line-height:1.6}
.cfx-sec-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.92rem;color:var(--cfx-amber);white-space:nowrap}
.cfx-sec-link svg{transition:transform .3s ease}
.cfx-sec-link:hover{color:var(--cfx-orange)}
.cfx-sec-link:hover svg{transform:translateX(4px)}

/* ---------- product cards ---------- */
.cfx-grid-products{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:22px}
.cfx-card{position:relative;display:flex;flex-direction:column;gap:16px;padding:30px 28px;border-radius:20px;background:linear-gradient(160deg,rgba(255,255,255,.055),rgba(255,255,255,.015));border:1px solid var(--cfx-border);overflow:hidden;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease}
.cfx-card::after{content:"";position:absolute;inset:0;background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),rgba(255,138,61,.13),transparent 65%);opacity:0;transition:opacity .4s ease;pointer-events:none}
.cfx-card:hover{transform:translateY(-6px);border-color:rgba(255,138,61,.42);box-shadow:0 22px 48px rgba(0,0,0,.45),0 0 0 1px rgba(255,138,61,.12)}
.cfx-card:hover::after{opacity:1}
.cfx-card-top{display:flex;align-items:center;justify-content:space-between}
.cfx-card-icon{display:grid;place-items:center;width:52px;height:52px;border-radius:15px;background:linear-gradient(150deg,rgba(255,107,44,.18),rgba(255,69,36,.06));border:1px solid rgba(255,138,61,.25);color:var(--cfx-amber)}
.cfx-tag{font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:5px 11px;border-radius:999px;border:1px solid rgba(61,220,132,.35);color:#3ddc84;background:rgba(61,220,132,.08)}
.cfx-tag-soon{border-color:rgba(255,169,77,.35);color:var(--cfx-amber);background:rgba(255,169,77,.08)}
.cfx-card h3{margin:4px 0 0;font-size:1.32rem;font-weight:700;letter-spacing:-.01em;color:var(--cfx-text)}
.cfx-card-kicker{font-size:.74rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--cfx-muted)}
.cfx-card p{margin:0;font-size:.95rem;line-height:1.65;color:var(--cfx-muted);flex-grow:1}
.cfx-card-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.9rem;color:var(--cfx-amber)}
.cfx-card-link svg{transition:transform .3s ease}
.cfx-card:hover .cfx-card-link svg{transform:translateX(5px)}
.cfx-card-soon{border-style:dashed;border-color:rgba(255,255,255,.16);background:transparent;align-items:center;justify-content:center;text-align:center}
.cfx-card-soon:hover{border-color:rgba(255,169,77,.4)}
.cfx-card-soon .cfx-card-icon{border-style:dashed}
.cfx-card-soon p{flex-grow:0}

/* ---------- blog ---------- */
.cfx-grid-posts{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.cfx-post{display:flex;flex-direction:column;border-radius:18px;overflow:hidden;background:var(--cfx-surface);border:1px solid var(--cfx-border);transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease}
.cfx-post:hover{transform:translateY(-5px);border-color:rgba(255,138,61,.38);box-shadow:0 18px 40px rgba(0,0,0,.4)}
.cfx-post-img{aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,#241410,#3b2a66)}
.cfx-post-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.cfx-post:hover .cfx-post-img img{transform:scale(1.06)}
.cfx-post-img-fallback{width:100%;height:100%;display:grid;place-items:center;font-size:2.6rem;font-weight:700;color:rgba(255,169,77,.5)}
.cfx-post-body{display:flex;flex-direction:column;gap:10px;padding:22px 22px 24px}
.cfx-post-meta{font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cfx-muted)}
.cfx-post-meta span{color:var(--cfx-amber)}
.cfx-post h3{margin:0;font-size:1.08rem;font-weight:700;line-height:1.4;letter-spacing:-.005em;color:var(--cfx-text);transition:color .3s ease}
.cfx-post:hover h3{color:var(--cfx-amber)}

/* ---------- newsletter ---------- */
.cfx-news{position:relative;border-radius:26px;padding:60px 48px;text-align:center;overflow:hidden;background:radial-gradient(ellipse 90% 130% at 8% -20%,rgba(255,107,44,.16),transparent 55%),radial-gradient(ellipse 90% 130% at 95% 120%,rgba(59,42,102,.35),transparent 55%),linear-gradient(160deg,rgba(255,255,255,.05),rgba(255,255,255,.015));border:1px solid rgba(255,138,61,.22)}
.cfx-news h2{margin:0 0 12px;font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:700;letter-spacing:-.015em;color:var(--cfx-text)}
.cfx-news p{margin:0 auto;max-width:480px;color:var(--cfx-muted);line-height:1.6}
.cfx-news-form{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.cfx-news-form input[type=email]{width:min(360px,100%);padding:15px 22px;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.35);color:var(--cfx-text);font-family:var(--cfx-font);font-size:.95rem;outline:none;transition:border-color .3s ease,box-shadow .3s ease}
.cfx-news-form input[type=email]::placeholder{color:rgba(245,239,232,.35)}
.cfx-news-form input[type=email]:focus{border-color:rgba(255,138,61,.6);box-shadow:0 0 0 4px rgba(255,107,44,.15)}
.cfx-news-form .cfx-btn-primary{border:none}
.cfx-news-status{margin-top:18px;font-size:.9rem;min-height:1.3em}
.cfx-news-status.ok{color:#3ddc84}
.cfx-news-status.err{color:#ff7b6b}

/* ---------- reveal ---------- */
.cfx-reveal{opacity:0;transform:translateY(26px);transition:opacity .75s cubic-bezier(.22,.65,.3,1),transform .75s cubic-bezier(.22,.65,.3,1);transition-delay:var(--rd,0s)}
.cfx-reveal.is-in{opacity:1;transform:translateY(0)}
body.cfx-no-js .cfx-reveal{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:760px){
  .cfx-hero{min-height:84vh;padding:96px 0 76px}
  .cfx-section{padding:68px 0}
  .cfx-sec-head{margin-bottom:36px}
  .cfx-news{padding:42px 24px}
  .cfx-cta-row .cfx-btn{width:100%;justify-content:center}
  .cfx-aurora{filter:blur(70px)}
}

@media (prefers-reduced-motion:reduce){
  .cfx-home-main *,.cfx-home-main *::before,.cfx-home-main *::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .cfx-reveal{opacity:1;transform:none}
  .cfx-scroll{display:none}
}

/* Header tagline + custom logo: site-dark.css doesn't load on the front page,
   so repeat the same fixes here */
.site-description {
    display: none;
}
.site-branding {
    display: flex !important;
    align-items: center;
    gap: 10px;
}
.site-logo img {
    height: 44px;
    width: auto;
    display: block;
}
