/* =====================================================================
   Jaxson Woods · Woodsy's Websites — Portfolio
   styles.css — DARK GLASSMORPHISM edition
   Vanilla CSS. Honest content only (no fake stats).
   - Animated gradient background + soft emerald glow
   - Glassmorphism cards (backdrop blur, hairline borders)
   - Interactive hover, tilt, cursor spotlight, scroll reveals
   - emil-design-eng: transform/opacity, custom easing, reduced-motion
   - Taste Skill: one accent, off-black, no Inter, no filler
   ===================================================================== */

:root {
  --bg:#08080a; --bg-soft:#0e0e12; --panel:#111116;
  --text:#f5f5f7; --muted:#a1a1aa; --faint:#71717a;
  --line:rgba(255,255,255,.09); --line-2:rgba(255,255,255,.14);
  --glass:rgba(255,255,255,.045); --glass-2:rgba(255,255,255,.075);
  --accent:#34d399; --accent-2:#10b981; --accent-deep:#059669;
  --glow:rgba(52,211,153,.22);
  --maxw:1200px; --r:16px; --r-lg:24px; --r-xl:30px;
  --ease-out:cubic-bezier(0.23,1,0.32,1); --t:240ms var(--ease-out);
  --nav-h:76px; --nav-h-sm:58px; --promo-h:40px;
  --font-display:"Space Grotesk", system-ui, sans-serif;
  --font-body:"Outfit", system-ui, -apple-system, sans-serif;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:calc(var(--nav-h) + var(--promo-h)); }
body { font-family:var(--font-body); background:var(--bg); color:var(--text);
  line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
h1,h2,h3 { font-family:var(--font-display); font-weight:700; line-height:1.05; letter-spacing:-.02em; color:#fff; }
a { color:inherit; text-decoration:none; } img { display:block; max-width:100%; }
.wrap { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 26px; }
.eyebrow { font-family:var(--font-body); font-size:.74rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--accent); }
.lead { color:var(--muted); font-size:1.1rem; max-width:58ch; }
.grad { background:linear-gradient(120deg,#fff 30%,var(--accent)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }

/* animated gradient background */
body::before { content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(50vw 45vh at 78% -8%, rgba(16,185,129,.22), transparent 60%),
    radial-gradient(42vw 40vh at 8% 12%, rgba(45,212,191,.14), transparent 62%),
    radial-gradient(45vw 45vh at 60% 108%, rgba(16,185,129,.12), transparent 60%);
  animation:bgshift 18s ease-in-out infinite alternate; }
@keyframes bgshift { 0%{transform:translate3d(0,0,0) scale(1)} 100%{transform:translate3d(-2%,2%,0) scale(1.08)} }
.grain { position:fixed; inset:0; z-index:1100; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:130px; }

/* buttons */
.btn { display:inline-flex; align-items:center; gap:.55rem; font-weight:600; font-size:.95rem;
  padding:.9rem 1.7rem; border-radius:100px; border:1.5px solid transparent; cursor:pointer; will-change:transform;
  transition:transform 160ms var(--ease-out), background var(--t), color var(--t), border-color var(--t), box-shadow var(--t); }
.btn-solid { background:var(--accent); color:#04120c; box-shadow:0 8px 30px -8px var(--glow); }
.btn-solid:hover { background:#4ade8c; box-shadow:0 12px 40px -10px var(--glow); }
.btn-solid:active { transform:scale(.97); }
.btn-solid::after { content:"\2192"; transition:transform 200ms var(--ease-out); }
.btn-solid:hover::after { transform:translateX(4px); }
.btn-glass { background:var(--glass); border-color:var(--line); color:#fff; backdrop-filter:blur(10px); }
.btn-glass:hover { background:var(--glass-2); border-color:var(--line-2); }
.btn-glass:active { transform:scale(.97); }

/* glass card mixin */
.glass { background:var(--glass); border:1px solid var(--line); border-radius:var(--r-lg);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); }

/* progress + promo bar */
.progress { position:fixed; top:var(--promo-h); left:0; height:2px; width:0; background:var(--accent); z-index:1300; box-shadow:0 0 10px var(--glow); }
.promo { position:fixed; inset:0 0 auto 0; height:var(--promo-h); z-index:1000; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(90deg,#063a2a,#0b7a57 45%,#0f9e70 55%,#063a2a); color:#eafff4; }
.promo-inner { display:flex; align-items:center; gap:11px; font-size:.85rem; padding:0 16px; white-space:nowrap; z-index:1; }
.promo-inner b { color:#fff; font-weight:700; } .promo-inner s { color:#bfe9d9; opacity:.8; }
.promo-dot { width:8px; height:8px; border-radius:50%; background:#9fe7cf; animation:pdot 1.8s var(--ease-out) infinite; }
.promo-cta { font-weight:700; color:#fff; border-bottom:1.5px solid rgba(255,255,255,.55); }
.promo-shine { position:absolute; top:0; bottom:0; left:-40%; width:35%; background:linear-gradient(100deg,transparent,rgba(255,255,255,.22),transparent); transform:skewX(-18deg); animation:pshine 5s linear infinite; }
@keyframes pdot { 0%,100%{box-shadow:0 0 0 0 rgba(159,231,207,.55)} 60%{box-shadow:0 0 0 9px rgba(159,231,207,0)} }
@keyframes pshine { 0%{left:-40%} 100%{left:130%} }
@media (max-width:560px){ :root{--promo-h:52px} .promo-inner{white-space:normal;text-align:center;font-size:.76rem;line-height:1.2} .promo-inner s{display:none} }

/* ===== Nav ===== */
.nav { position:fixed; inset:var(--promo-h) 0 auto 0; height:var(--nav-h); z-index:900; display:flex; align-items:center;
  transition:height var(--t), background var(--t), border-color var(--t); border-bottom:1px solid transparent; }
.nav.scrolled { height:var(--nav-h-sm); background:rgba(8,8,10,.72); backdrop-filter:blur(14px); border-bottom-color:var(--line); }
.nav .wrap { display:flex; align-items:center; justify-content:space-between; }
.brand { display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:700; font-size:1.2rem; color:#fff; }
.brand .dot { color:var(--accent); }
.nav-links { display:flex; align-items:center; gap:30px; list-style:none; }
.nav-links a { position:relative; font-size:.94rem; font-weight:500; color:var(--muted); transition:color var(--t); }
.nav-links a:not(.btn)::after { content:""; position:absolute; left:0; bottom:-5px; height:2px; width:0; background:var(--accent); transition:width var(--t); }
.nav-links a:hover, .nav-links a.active:not(.btn) { color:#fff; }
.nav-links a.active:not(.btn)::after { width:100%; }
.nav-links .btn { color:#04120c; }
.burger { display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.burger span { width:24px; height:2px; background:#fff; transition:var(--t); }
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== Hero ===== */
.hero { padding:calc(var(--nav-h) + var(--promo-h) + 64px) 0 80px; position:relative; overflow:hidden; }
.hero .spot { position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(380px 380px at var(--mx,80%) var(--my,20%), rgba(52,211,153,.10), transparent 70%); transition:background .12s linear; }
.hero .wrap { position:relative; z-index:1; }
.hero-grid { display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.badge { display:inline-flex; align-items:center; gap:8px; font-size:.72rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:#d4f5e6;
  background:var(--glass); border:1px solid var(--line); border-radius:100px; padding:.45rem 1rem; backdrop-filter:blur(8px); }
.badge .ping { position:relative; display:flex; width:8px; height:8px; }
.badge .ping i { position:absolute; inset:0; border-radius:50%; background:var(--accent); }
.badge .ping i:first-child { animation:ping 1.8s var(--ease-out) infinite; }
@keyframes ping { 75%,100%{ transform:scale(2.4); opacity:0 } }
.hero h1 { font-size:clamp(2.7rem,6.4vw,5rem); margin:20px 0 22px; max-width:16ch; }
.rot-line { display:block; height:1.15em; line-height:1.15em; white-space:nowrap; overflow:hidden; }
.rotate { color:var(--accent); }
.caret { display:inline-block; width:3px; height:.8em; background:var(--accent); margin-left:3px; vertical-align:-2px; animation:blink 1s steps(1) infinite; }
@keyframes blink { 50%{opacity:0} }
.hero p { color:var(--muted); margin-bottom:30px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; }
.hero .anim { opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); }
body.loaded .hero .anim { opacity:1; transform:none; }
body.loaded .hero .anim:nth-child(1){transition-delay:.05s}
body.loaded .hero .anim:nth-child(2){transition-delay:.15s}
body.loaded .hero .anim:nth-child(3){transition-delay:.25s}
body.loaded .hero .anim:nth-child(4){transition-delay:.35s}

/* hero right column glass cards */
.hero-cards { display:grid; gap:18px; }
.hi-card { position:relative; overflow:hidden; padding:26px; }
.hi-card .cardglow { position:absolute; top:-40px; right:-40px; width:180px; height:180px; border-radius:50%; background:var(--glow); filter:blur(50px); pointer-events:none; }
.hi-top { display:flex; align-items:center; gap:14px; margin-bottom:20px; position:relative; z-index:1; }
.hi-top .ic { width:46px; height:46px; border-radius:14px; background:var(--glass-2); border:1px solid var(--line-2); display:grid; place-items:center; }
.hi-top .ic svg { width:22px; height:22px; stroke:var(--accent); }
.hi-top b { font-family:var(--font-display); font-size:1.35rem; color:#fff; display:block; }
.hi-top span { font-size:.85rem; color:var(--muted); }
.spots { position:relative; z-index:1; margin-bottom:8px; }
.spots .row { display:flex; justify-content:space-between; font-size:.85rem; margin-bottom:8px; }
.spots .row .muted { color:var(--muted); } .spots .row .v { color:#fff; font-weight:600; }
.spots .track { height:8px; border-radius:100px; background:rgba(255,255,255,.08); overflow:hidden; }
.spots .fill { height:100%; width:33%; border-radius:100px; background:linear-gradient(90deg,var(--accent),#a7f3d0); }
.hi-div { height:1px; background:var(--line); margin:20px 0; }
.hi-grid { display:grid; grid-template-columns:1fr auto 1fr auto 1fr; gap:10px; text-align:center; align-items:center; position:relative; z-index:1; }
.hi-grid .sep { width:1px; height:34px; background:var(--line); }
.hi-grid .n { font-family:var(--font-display); font-weight:700; color:#fff; font-size:1.15rem; }
.hi-grid .l { font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:var(--faint); }
.pills { display:flex; flex-wrap:wrap; gap:8px; margin-top:20px; position:relative; z-index:1; }
.pill { display:inline-flex; align-items:center; gap:7px; font-size:.68rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:#d4d4d8;
  border:1px solid var(--line); border-radius:100px; padding:.35rem .7rem; background:var(--glass); }
.pill .gdot { width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 8px var(--accent); }

/* marquee card (real projects) */
.mq-card { padding:22px 0; overflow:hidden; }
.mq-card h4 { font-size:.8rem; font-weight:500; color:var(--muted); padding:0 26px 14px; }
.mq-mask { position:relative; overflow:hidden; -webkit-mask-image:linear-gradient(to right,transparent,#000 18%,#000 82%,transparent); mask-image:linear-gradient(to right,transparent,#000 18%,#000 82%,transparent); }
.mq-track { display:flex; gap:2.6rem; white-space:nowrap; padding:0 26px; animation:marquee 32s linear infinite; }
.mq-track span { font-family:var(--font-display); font-weight:700; font-size:1.05rem; color:#fff; opacity:.55; transition:opacity var(--t); }
.mq-track span:hover { opacity:1; }
@keyframes marquee { to { transform:translateX(-50%); } }

/* ===== Sections ===== */
.section { padding:96px 0; position:relative; }
.s-head { max-width:640px; margin-bottom:50px; }
.s-head h2 { font-size:clamp(2rem,4.4vw,3rem); margin:12px 0 12px; }

/* about */
.split { display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:center; }
.about-card { padding:30px; }
.about-card img { width:88px; height:88px; border-radius:22px; margin-bottom:18px; }
.about-card h3 { font-size:1.25rem; } .about-card .role { color:var(--accent); font-weight:600; font-size:.9rem; margin-bottom:14px; }
.about-card ul { list-style:none; display:grid; gap:10px; }
.about-card li { display:flex; gap:10px; font-size:.94rem; color:var(--muted); }
.about-card li::before { content:"\2713"; color:var(--accent); font-weight:700; }
.split h2 { font-size:clamp(1.9rem,3.6vw,2.6rem); margin-bottom:1rem; }
.split p + p { margin-top:1rem; color:var(--muted); }

/* work */
.work { display:grid; gap:26px; }
.project { position:relative; display:grid; grid-template-columns:1.1fr .9fr; gap:36px; align-items:center;
  padding:24px; overflow:hidden; transform-style:preserve-3d; will-change:transform;
  transition:transform 240ms var(--ease-out), border-color var(--t), box-shadow var(--t); }
.project::before { content:""; position:absolute; inset:0; z-index:0; opacity:0; transition:opacity var(--t);
  background:radial-gradient(420px 420px at var(--mx,50%) var(--my,50%), rgba(52,211,153,.12), transparent 60%); }
.project:hover { border-color:var(--line-2); box-shadow:0 30px 70px -40px rgba(0,0,0,.8); }
.project:hover::before { opacity:1; }
.project > * { position:relative; z-index:1; }
.project:nth-child(even) .project-media { order:2; }
.project-media { border-radius:var(--r); overflow:hidden; border:1px solid var(--line); }
.project-media img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease-out); }
.project:hover .project-media img { transform:scale(1.04); }
.project .tag { display:inline-block; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); background:rgba(52,211,153,.12); border:1px solid rgba(52,211,153,.25); padding:.3rem .7rem; border-radius:100px; margin-bottom:12px; }
.project h3 { font-size:1.6rem; margin-bottom:8px; }
.project p { color:var(--muted); margin-bottom:14px; }
.chips { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px; }
.chips span { font-size:.74rem; color:var(--faint); border:1px solid var(--line); border-radius:100px; padding:.25rem .6rem; }
.project-links a { font-weight:600; font-size:.92rem; color:var(--accent); }
.project-links a:hover { color:#6ee7b7; }
.project-links .soon { color:var(--faint); font-weight:500; }

/* services */
.svc { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.svc-card { padding:32px; transition:transform var(--t), box-shadow var(--t), border-color var(--t); }
.svc-card:hover { transform:translateY(-4px); border-color:var(--line-2); box-shadow:0 30px 70px -42px rgba(0,0,0,.85); }
.svc-card.feature { background:linear-gradient(160deg, rgba(52,211,153,.14), var(--glass)); border-color:rgba(52,211,153,.3); }
.launch-badge { display:inline-block; background:var(--accent); color:#04120c; font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:.3rem .7rem; border-radius:100px; margin-bottom:12px; }
.svc-card h3 { font-size:1.4rem; margin-bottom:6px; }
.svc-card .price { font-family:var(--font-display); font-size:2.2rem; color:#fff; margin:8px 0 6px; }
.svc-card .price .now { color:var(--accent); }
.svc-card .price s { font-size:1.2rem; color:var(--faint); font-weight:500; margin-left:4px; }
.svc-card .price small { font-family:var(--font-body); font-size:.9rem; font-weight:500; color:var(--faint); }
.svc-card p { color:var(--muted); font-size:.96rem; }
.svc-card ul { list-style:none; display:grid; gap:9px; margin-top:14px; }
.svc-card li { display:flex; gap:10px; font-size:.94rem; color:var(--muted); }
.svc-card li::before { content:"\2713"; color:var(--accent); font-weight:700; }

/* contact */
.contact { text-align:center; }
.contact-inner { padding:56px 30px; }
.contact h2 { font-size:clamp(2rem,5vw,3.2rem); margin-bottom:14px; }
.contact p { color:var(--muted); margin-bottom:26px; }
.contact .email { font-family:var(--font-display); font-size:clamp(1.1rem,2.6vw,1.6rem); color:var(--accent); display:inline-block; margin-top:6px; }
.contact .email:hover { color:#6ee7b7; }

/* footer */
.footer { border-top:1px solid var(--line); padding:40px 0; color:var(--faint); }
.footer .wrap { display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:.86rem; }
.footer .brand { color:#fff; font-size:1rem; }
.footer a:hover { color:#fff; }

/* back to top */
.totop { position:fixed; right:22px; bottom:22px; z-index:1000; width:46px; height:46px; border-radius:50%;
  background:var(--accent); color:#04120c; border:0; cursor:pointer; font-size:1.2rem; display:grid; place-items:center;
  opacity:0; transform:translateY(14px) scale(.9); pointer-events:none; transition:opacity var(--t), transform var(--t); box-shadow:0 10px 30px -8px var(--glow); }
.totop.show { opacity:1; transform:none; pointer-events:auto; }
.totop:active { transform:scale(.94); }

/* reveal + cursor glow */
.reveal { opacity:0; transform:translateY(20px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.reveal.in { opacity:1; transform:none; }
.cursor-glow { position:fixed; inset:0; z-index:50; pointer-events:none; opacity:0; transition:opacity .8s ease;
  background:radial-gradient(320px 320px at var(--cx,50%) var(--cy,50%), rgba(52,211,153,.07), transparent 66%); }
body.cursor-on .cursor-glow { opacity:1; }

@media (prefers-reduced-motion: reduce){
  *{animation:none!important} html{scroll-behavior:auto}
  .reveal,.hero .anim{opacity:1!important;transform:none!important;transition:none}
  .cursor-glow,.promo-shine{display:none} body::before{animation:none}
}

/* responsive */
@media (max-width:900px){
  .hero-grid,.split,.svc,.project{grid-template-columns:1fr;gap:30px}
  .project:nth-child(even) .project-media{order:0}
}
@media (max-width:640px){
  .burger{display:flex}
  .wrap{padding:0 20px}
  .nav-links{position:fixed;inset:calc(var(--nav-h) + var(--promo-h)) 0 auto 0;flex-direction:column;gap:0;padding:6px 0 16px;
    background:rgba(8,8,10,.96);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
    transform:translateY(-130%);opacity:0;visibility:hidden;
    transition:transform var(--t),opacity var(--t),visibility 0s linear var(--t)}
  .nav-links.open{transform:translateY(0);opacity:1;visibility:visible;transition:transform var(--t),opacity var(--t),visibility 0s}
  .nav.scrolled .nav-links{top:calc(var(--nav-h-sm) + var(--promo-h))}
  .nav-links li{width:100%;text-align:center} .nav-links a{display:block;padding:14px} .nav-links a:not(.btn)::after{display:none}
  .nav-links li:last-child{padding:10px 0 4px}
  .nav-links .btn-solid{display:inline-flex;width:auto;padding:.62rem 1.4rem;font-size:.88rem}
  .section{padding:70px 0} .hero{padding-top:calc(var(--nav-h) + var(--promo-h) + 36px)} .hero-actions .btn{flex:1;justify-content:center}
  .hi-grid{grid-template-columns:1fr auto 1fr auto 1fr}
}
