/* ============================================================
   Caio Costa — Portfolio Styles
   Vibrant warm amber palette · Animated · Modern 2025/2026
   ============================================================ */

:root {
  --text-xs:   clamp(.75rem,  .72rem + .16vw, .875rem);
  --text-sm:   clamp(.875rem, .84rem + .2vw,  1rem);
  --text-base: clamp(1rem,    .97rem + .2vw,  1.125rem);
  --text-lg:   clamp(1.125rem, 1rem + .6vw,   1.45rem);
  --text-xl:   clamp(1.6rem,  1.25rem + 1.25vw, 2.3rem);
  --text-2xl:  clamp(2.25rem, 1.3rem + 2.8vw, 4.5rem);

  --space-1: .25rem;  --space-2: .5rem;   --space-3: .75rem;
  --space-4: 1rem;    --space-5: 1.25rem; --space-6: 1.5rem;
  --space-8: 2rem;    --space-10: 2.5rem; --space-12: 3rem;
  --space-16: 4rem;   --space-20: 5rem;   --space-24: 6rem;

  --radius-sm: .5rem; --radius-md: .9rem; --radius-lg: 1.2rem;
  --radius-xl: 1.8rem; --radius-pill: 999px;

  --shadow-sm: 0 10px 30px rgba(0,0,0,.12);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.22);

  --content: 1160px;
  --font-display: 'Boska', Georgia, serif;
  --font-body: 'Satoshi', Inter, sans-serif;

  --ease-out-quart: cubic-bezier(.25,1,.5,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
}

/* ── LIGHT THEME — vibrant warm amber ── */
:root, [data-theme="light"] {
  --bg: #f7ede0;
  --bg-soft: #f1e3cf;
  --surface: rgba(255,255,255,.68);
  --surface-2: rgba(255,255,255,.48);
  --line: rgba(67,48,27,.16);
  --line-strong: rgba(67,48,27,.28);
  --text: #1f120a;
  --muted: #6c5a44;
  --accent: #c2410c;          /* vibrant burnt orange */
  --accent-2: #ea9b1f;        /* gold amber */
  --accent-3: #f59e0b;        /* warm gold */
  --accent-soft: rgba(194,65,12,.12);
  --accent-glow: rgba(234,155,31,.45);
  --success: #355d38;
  --glow-1: rgba(234,155,31,.38);
  --glow-2: rgba(194,65,12,.24);
  --glow-3: rgba(245,158,11,.16);
  --hero-glow:
    radial-gradient(circle at 18% 22%, rgba(234,155,31,.38), transparent 38%),
    radial-gradient(circle at 82% 12%, rgba(194,65,12,.24), transparent 32%),
    radial-gradient(circle at 50% 95%, rgba(245,158,11,.16), transparent 40%);
}

/* ── DARK THEME — rich vibrant amber ── */
[data-theme="dark"] {
  --bg: #120c08;
  --bg-soft: #1a110c;
  --surface: rgba(38,26,19,.86);
  --surface-2: rgba(60,42,32,.58);
  --line: rgba(255,224,180,.13);
  --line-strong: rgba(255,224,180,.24);
  --text: #f5e8d4;
  --muted: #c4ad8e;
  --accent: #f97316;          /* vibrant orange */
  --accent-2: #fbbf24;        /* warm gold */
  --accent-3: #f59e0b;        /* amber */
  --accent-soft: rgba(249,115,22,.14);
  --accent-glow: rgba(251,191,36,.45);
  --success: #8cbb8f;
  --glow-1: rgba(251,191,36,.18);
  --glow-2: rgba(249,115,22,.18);
  --glow-3: rgba(245,158,11,.12);
  --hero-glow:
    radial-gradient(circle at 18% 22%, rgba(251,191,36,.18), transparent 38%),
    radial-gradient(circle at 82% 12%, rgba(249,115,22,.18), transparent 32%),
    radial-gradient(circle at 50% 95%, rgba(245,158,11,.12), transparent 40%);
}

/* ── Base ── */
* { box-sizing: border-box; cursor: none; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--text);
  background: var(--bg);
  background-attachment: fixed;
  transition: background-color .5s ease, color .5s ease;
  cursor: none;
  position: relative;
}
body::before,
body::after {
  content: "";
  position: fixed; inset: -15%;
  z-index: -1;
  pointer-events: none;
  will-change: transform, filter;
}
body::before {
  background:
    linear-gradient(180deg, transparent, rgba(0,0,0,0.04)),
    radial-gradient(circle at 18% 22%, var(--glow-1), transparent 38%),
    radial-gradient(circle at 82% 12%, var(--glow-2), transparent 32%),
    radial-gradient(circle at 50% 95%, var(--glow-3), transparent 40%);
  animation: bgDrift1 25s ease-in-out infinite, bgHue1 18s ease-in-out infinite;
}
body::after {
  background:
    radial-gradient(circle at 70% 60%, var(--glow-1), transparent 35%),
    radial-gradient(circle at 25% 80%, var(--glow-2), transparent 30%),
    radial-gradient(circle at 60% 15%, var(--glow-3), transparent 35%);
  opacity: .6;
  animation: bgDrift2 30s ease-in-out infinite, bgHue2 22s ease-in-out infinite;
}
@keyframes bgDrift1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  25%      { transform: translate(3%, -2%) scale(1.03); }
  50%      { transform: translate(-2%, 3%) scale(1.01); }
  75%      { transform: translate(1%, -1%) scale(1.04); }
}
@keyframes bgDrift2 {
  0%, 100% { transform: translate(0, 0) scale(1.02); }
  33%      { transform: translate(-4%, 2%) scale(1); }
  66%      { transform: translate(3%, -3%) scale(1.05); }
}
@keyframes bgHue1 {
  0%, 100% { filter: hue-rotate(0deg); }
  33%      { filter: hue-rotate(-12deg); }
  66%      { filter: hue-rotate(15deg); }
}
@keyframes bgHue2 {
  0%, 100% { filter: hue-rotate(0deg); }
  50%      { filter: hue-rotate(-18deg); }
}
a { color: inherit; cursor: none; }
img, svg { max-width: 100%; display: block; }
button { font: inherit; cursor: none; }
.container { width: min(calc(100% - 2rem), var(--content)); margin: 0 auto; }
/* Restore default cursor on touch/coarse devices */
@media (hover: none), (pointer: coarse) {
  * { cursor: auto !important; }
  a { cursor: pointer !important; }
  button { cursor: pointer !important; }
}
.skip-link {
  position: absolute; left: -999px; top: 0;
  background: var(--accent); color: #fff; padding: .75rem 1rem; z-index: 200;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* ── Scroll progress bar ── */
.scroll-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2), var(--accent-3));
  background-size: 200% 100%;
  transform-origin: 0 50%;
  transform: scaleX(0);
  z-index: 99;
  box-shadow: 0 0 12px var(--accent-glow);
  animation: gradientShift 4s ease-in-out infinite;
}
@keyframes gradientShift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* ── Custom cursor ── */
.cursor-dot, .cursor-ring {
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9999;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
}
.cursor-dot {
  width: 8px; height: 8px;
  background: var(--accent-2);
  transition: width .2s var(--ease-spring), height .2s var(--ease-spring),
              background-color .2s ease;
}
.cursor-ring {
  width: 38px; height: 38px;
  border: 1.5px solid var(--accent);
  transition: transform .12s var(--ease-out-quart), width .25s var(--ease-spring),
              height .25s var(--ease-spring), border-color .2s ease,
              background-color .2s ease;
}
.cursor-ring.hover {
  width: 60px; height: 60px;
  background: var(--accent-soft);
  border-color: var(--accent-2);
}
.cursor-dot.hover {
  width: 14px; height: 14px;
}
.cursor-ring.click {
  transform: translate(-50%, -50%) scale(.7);
}
@media (hover: none), (pointer: coarse) {
  .cursor-dot, .cursor-ring { display: none; }
}

/* ── Header ── */
.site-header {
  position: sticky; top: 0; z-index: 20;
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  border-bottom: 1px solid var(--line);
  transition: background-color .4s ease, border-color .4s ease;
}
.nav {
  display: flex; align-items: center; justify-content: space-between;
  min-height: 4.5rem; gap: var(--space-4);
}
.brand {
  display: inline-flex; align-items: center; gap: .9rem; text-decoration: none;
  font-weight: 700;
}
.brand-mark {
  width: 2.4rem; height: 2.4rem; border-radius: 50%;
  display: grid; place-items: center; color: var(--text);
  background: linear-gradient(135deg, var(--accent-soft), rgba(255,255,255,.05));
  border: 1px solid var(--line);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  transition: transform .35s var(--ease-spring), box-shadow .35s ease;
}
.brand:hover .brand-mark {
  transform: rotate(-8deg) scale(1.08);
  box-shadow: 0 0 0 4px var(--accent-soft), inset 0 1px 0 rgba(255,255,255,.06);
}
.nav-links { display: flex; gap: var(--space-4); align-items: center; flex-wrap: wrap; }
.nav-links a {
  text-decoration: none; color: var(--muted); font-size: var(--text-sm);
  position: relative; padding: .3rem .1rem;
  transition: color .25s ease;
}
.nav-links a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px; background: linear-gradient(90deg, var(--accent), var(--accent-2));
  border-radius: 2px;
  transform: scaleX(0); transform-origin: right;
  transition: transform .35s var(--ease-out-quart);
}
.nav-links a:hover, .nav-links a:focus-visible { color: var(--text); }
.nav-links a:hover::after, .nav-links a:focus-visible::after {
  transform: scaleX(1); transform-origin: left;
}

.theme-toggle, .lang-toggle {
  display: inline-grid; place-items: center; width: 2.6rem; height: 2.6rem;
  border-radius: 50%; border: 1px solid var(--line); background: var(--surface); color: var(--text);
  cursor: pointer; position: relative;
  transition: transform .3s var(--ease-spring), border-color .25s ease,
              box-shadow .3s ease, background .25s ease;
}
.theme-toggle:hover, .lang-toggle:hover {
  transform: translateY(-2px) rotate(-6deg);
  border-color: var(--accent);
  box-shadow: 0 6px 20px var(--accent-soft);
}
.lang-toggle .lang-code {
  position: absolute; bottom: -2px; right: -2px;
  font-size: .55rem; font-weight: 700; text-transform: uppercase;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; padding: .1rem .3rem;
  border-radius: var(--radius-pill); line-height: 1; letter-spacing: .03em;
  box-shadow: 0 2px 8px var(--accent-soft);
}
.lang-wrap { position: relative; }
.lang-menu {
  position: absolute; top: calc(100% + .6rem); right: 0; z-index: 30;
  min-width: 11rem; padding: .4rem;
  background: color-mix(in srgb, var(--bg) 95%, transparent);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--line); border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  opacity: 0; visibility: hidden; transform: translateY(-8px) scale(.96);
  transition: opacity .25s ease, transform .25s var(--ease-spring), visibility .25s;
  max-height: 70vh; overflow-y: auto;
}
.lang-menu.open { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
.lang-menu button {
  display: flex; align-items: center; gap: .6rem;
  width: 100%; padding: .55rem .75rem; border: none; background: none;
  color: var(--text); font-size: var(--text-sm);
  border-radius: calc(var(--radius-md) - .2rem);
  cursor: pointer; text-align: left;
  transition: background .2s ease, color .2s ease, transform .15s ease;
}
.lang-menu button:hover { background: var(--accent-soft); transform: translateX(2px); }
.lang-menu button.active { color: var(--accent); font-weight: 700; }
.lang-menu button .flag { font-size: 1.1rem; }

main { overflow: clip; }
section { padding: clamp(var(--space-12), 7vw, var(--space-24)) 0; position: relative; }

/* ── Eyebrow badge with subtle pulse glow ── */
.eyebrow {
  display: inline-flex; gap: .6rem; align-items: center; margin-bottom: var(--space-4);
  padding: .45rem .9rem; border-radius: var(--radius-pill); border: 1px solid var(--line);
  background: var(--surface-2); color: var(--muted); font-size: var(--text-sm);
  width: fit-content;
  transition: border-color .3s ease, color .3s ease, transform .3s var(--ease-spring);
}
.eyebrow::before {
  content: ""; width: .5rem; height: .5rem; border-radius: 50%;
  background: var(--accent-2);
  box-shadow: 0 0 0 .25rem var(--accent-soft);
  animation: pulseGlow 2.4s ease-in-out infinite;
}
@keyframes pulseGlow {
  0%, 100% { box-shadow: 0 0 0 .25rem var(--accent-soft), 0 0 0 0 var(--accent-glow); }
  50% { box-shadow: 0 0 0 .35rem var(--accent-soft), 0 0 0 .55rem transparent; }
}
.eyebrow:hover {
  border-color: var(--accent);
  color: var(--text);
  transform: translateY(-1px);
}

h1, h2, h3 { margin: 0; line-height: 1.05; }
h1, h2 { font-family: var(--font-display); letter-spacing: -.02em; }
h1 { font-size: var(--text-2xl); max-width: 12ch; }
h2 {
  font-size: clamp(2rem, 1.3rem + 2vw, 3.25rem);
  margin-bottom: var(--space-4);
}
h3 { font-size: clamp(1.2rem, 1.05rem + .5vw, 1.6rem); margin-bottom: .5rem; }
p { margin: 0; max-width: 68ch; }
.lead { font-size: var(--text-lg); color: var(--muted); max-width: 38rem; }
.section-copy { color: var(--muted); margin-bottom: var(--space-8); }

/* Gradient sweep on the H1 accent words */
.h1-accent {
  background: linear-gradient(120deg, var(--accent) 0%, var(--accent-2) 50%, var(--accent-3) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: gradientShift 6s ease-in-out infinite;
}

/* Word-by-word reveal */
.word {
  display: inline-block;
  opacity: 0;
  transform: translateY(.6em);
  filter: blur(6px);
  transition: opacity .7s var(--ease-out-quart),
              transform .7s var(--ease-out-quart),
              filter .7s var(--ease-out-quart);
}
.word.in {
  opacity: 1; transform: translateY(0); filter: blur(0);
}

/* ── HERO ── */
.hero-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: clamp(2rem, 4vw, 3rem);
  align-items: start;
}
.hero-copy { display: flex; flex-direction: column; gap: var(--space-5); }
.hero-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; padding-top: var(--space-2); }

.button {
  display: inline-flex; align-items: center; justify-content: center; gap: .65rem;
  min-height: 2.9rem; padding: .85rem 1.25rem; border-radius: var(--radius-pill);
  text-decoration: none; border: 1px solid var(--line);
  font-weight: 600;
  position: relative; overflow: hidden;
  transition: transform .3s var(--ease-spring),
              border-color .25s ease,
              background .25s ease,
              box-shadow .3s ease;
}
.button::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.25) 50%, transparent 70%);
  transform: translateX(-110%);
  transition: transform .7s var(--ease-out-quart);
}
.button:hover::before, .button:focus-visible::before { transform: translateX(110%); }
.button:hover, .button:focus-visible {
  transform: translateY(-3px);
  border-color: var(--line-strong);
  box-shadow: 0 12px 30px rgba(0,0,0,.18), 0 0 0 4px var(--accent-soft);
}
.button.primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  background-size: 200% 200%;
  color: #fff; border-color: transparent; box-shadow: var(--shadow-sm), 0 6px 20px var(--accent-soft);
  animation: gradientShift 8s ease-in-out infinite;
}
.button.primary:hover, .button.primary:focus-visible {
  box-shadow: var(--shadow-lg), 0 0 0 4px var(--accent-soft);
}
.button.secondary { background: var(--surface); }

.hero-panel {
  grid-column: 1 / -1;
  margin-top: var(--space-6);
  position: relative;
  width: 100%; min-height: unset; padding: .9rem;
  border-radius: calc(var(--radius-xl) + .5rem);
  background: linear-gradient(180deg, var(--surface), rgba(0,0,0,.03));
  border: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
  overflow: hidden; isolation: isolate;
  transition: transform .5s var(--ease-out-quart), box-shadow .5s ease;
}
.hero-panel:hover { transform: translateY(-4px); box-shadow: 0 30px 80px rgba(0,0,0,.28); }
.hero-panel::after {
  content: "";
  position: absolute;
  inset: auto -20% -15% 25%; height: 15rem;
  background: radial-gradient(circle, var(--accent-glow), transparent 65%);
  filter: blur(20px); z-index: -1;
  animation: floatGlow 8s ease-in-out infinite;
}
@keyframes floatGlow {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: .8; }
  50% { transform: translate(-3%, -4%) scale(1.05); opacity: 1; }
}
.hero-panel img {
  width: 100%; height: auto; display: block;
  aspect-ratio: 5 / 4;
  object-fit: contain; object-position: center;
  border-radius: calc(var(--radius-xl) - 8px);
}
.map-note {
  position: absolute; inset: 1rem 1rem auto auto;
  padding: .6rem 1rem; border-radius: var(--radius-pill);
  font-size: var(--text-sm); color: var(--text); font-weight: 700;
  white-space: nowrap; max-width: calc(100% - 2rem); overflow: hidden; text-overflow: ellipsis;
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  border: 2px solid var(--accent); backdrop-filter: blur(12px);
  box-shadow: 0 4px 20px var(--accent-soft);
  z-index: 2;
}
.stats {
  display: flex; flex-direction: column; gap: var(--space-5);
  align-self: center; justify-self: center;
  width: 100%; max-width: 26rem;
}
.stat {
  padding: 1.5rem; border-radius: var(--radius-lg); background: var(--surface);
  border: 1px solid var(--line); box-shadow: var(--shadow-sm);
  position: relative; overflow: hidden;
  transition: transform .35s var(--ease-spring),
              border-color .3s ease,
              box-shadow .35s ease;
}
.stat::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--accent-soft), transparent 60%);
  opacity: 0; transition: opacity .35s ease;
}
.stat:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
  box-shadow: 0 16px 40px var(--accent-soft);
}
.stat:hover::before { opacity: 1; }
.stat > * { position: relative; z-index: 1; }
.stat strong {
  display: block; font-size: 1.7rem; margin-bottom: .4rem; letter-spacing: -.02em;
  background: linear-gradient(120deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.stat span { color: var(--muted); font-size: var(--text-base); }

/* ── ABOUT ── */
.about-grid {
  display: grid; grid-template-columns: 1.2fr .8fr; gap: var(--space-8); align-items: center;
}
.about-image { position: relative; }
.about-image img {
  width: 100%; height: auto;
  border-radius: var(--radius-xl); border: 1px solid var(--line);
  box-shadow: var(--shadow-sm); aspect-ratio: 4 / 5; object-fit: cover; background: var(--surface);
  transition: transform .6s var(--ease-out-quart), box-shadow .6s ease;
}
.about-image:hover img { transform: scale(1.02) rotate(-.5deg); box-shadow: var(--shadow-lg); }
.about-image::before {
  content: ""; position: absolute; inset: -1.5rem -1.5rem 1rem 1.5rem;
  background: radial-gradient(circle at 10% 20%, var(--accent-glow), transparent 60%);
  filter: blur(20px); z-index: -1;
  animation: floatGlow 10s ease-in-out infinite reverse;
}
.about-copy { display: flex; flex-direction: column; gap: var(--space-4); }
.about-copy p:not(.lead) { color: var(--muted); }

/* ── QUEST STEPS ── */
.quest-card {
  padding: 1.1rem 1rem; border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  border: 1px solid var(--line);
  transition: border-color .3s ease, transform .3s var(--ease-spring);
}
.quest-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
}
.quest-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: var(--space-4); }
.quest-step {
  position: relative; padding: var(--space-6); background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius-lg); min-height: 15rem;
  overflow: hidden;
  transition: transform .4s var(--ease-spring),
              border-color .3s ease,
              box-shadow .4s ease;
}
.quest-step::after {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  transform: scaleX(0); transform-origin: left;
  transition: transform .5s var(--ease-out-quart);
}
.quest-step:hover {
  transform: translateY(-6px);
  border-color: var(--accent);
  box-shadow: 0 20px 50px var(--accent-soft);
}
.quest-step:hover::after { transform: scaleX(1); }
.quest-step small {
  color: var(--accent-2); display: block; margin-bottom: .8rem;
  letter-spacing: .08em; text-transform: uppercase; font-weight: 700;
}
.quest-step p { color: var(--muted); font-size: var(--text-sm); }

/* ── PROJECTS ── */
.project-groups { display: grid; gap: var(--space-10); }
.project-group-head { margin-bottom: var(--space-8); }
.project-group-head p { color: var(--muted); max-width: 48rem; margin-top: var(--space-2); }
.cards { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: var(--space-4); }
.card {
  display: flex; flex-direction: column; gap: var(--space-4); padding: var(--space-5);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--surface), color-mix(in srgb, var(--surface) 82%, transparent));
  border: 1px solid var(--line); min-height: 19rem; box-shadow: var(--shadow-sm);
  position: relative; overflow: hidden;
  transition: transform .4s var(--ease-spring),
              border-color .3s ease,
              box-shadow .4s ease;
}
.card::before {
  content: ""; position: absolute; inset: 0; padding: 1px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2), transparent 50%);
  border-radius: var(--radius-lg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0; transition: opacity .35s ease; pointer-events: none;
}
.card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 60px rgba(0,0,0,.22), 0 0 0 1px var(--accent-soft);
  border-color: transparent;
}
.card:hover::before { opacity: 1; }
.card-art {
  aspect-ratio: 16 / 10; border-radius: calc(var(--radius-lg) - .45rem); border: 1px solid var(--line);
  background:
    radial-gradient(circle at 20% 30%, var(--accent-glow), transparent 30%),
    radial-gradient(circle at 70% 35%, var(--accent-soft), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.06)),
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, transparent), transparent 65%);
  position: relative; overflow: hidden;
}
.card-art svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.card-art img {
  width: 100%; height: 100%; object-fit: cover; object-position: center; display: block;
  transition: transform .6s var(--ease-out-quart);
}
.card:hover .card-art img { transform: scale(1.06); }
.tag-row { display: flex; gap: .5rem; flex-wrap: wrap; }
.tag {
  padding: .28rem .6rem; border-radius: var(--radius-pill); background: var(--accent-soft);
  border: 1px solid var(--line); color: var(--muted); font-size: var(--text-xs);
  transition: color .25s ease, border-color .25s ease, transform .25s ease;
}
.card:hover .tag { color: var(--text); border-color: var(--line-strong); }
.card p { color: var(--muted); font-size: var(--text-sm); }
.card a {
  margin-top: auto; text-decoration: none; font-weight: 700; color: var(--accent);
  display: inline-flex; align-items: center; gap: .4rem;
  transition: gap .3s var(--ease-out-quart), color .25s ease;
}
.card a:hover { gap: .7rem; color: var(--accent-2); }

/* ── SKILLS ── */
.skills-wrap {
  display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: var(--space-6);
}
.panel {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: var(--space-6); box-shadow: var(--shadow-sm);
  transition: border-color .3s ease, transform .35s var(--ease-spring), box-shadow .35s ease;
}
.panel:hover {
  border-color: var(--line-strong);
  transform: translateY(-3px);
  box-shadow: 0 18px 45px rgba(0,0,0,.16);
}
.skill-list, .contact-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .9rem; }
.skill-list li, .contact-list li {
  padding: .85rem 0; border-bottom: 1px solid var(--line);
  transition: padding .3s ease;
}
.skill-list li:last-child, .contact-list li:last-child { border-bottom: none; padding-bottom: 0; }
.skill-list li:hover { padding-left: .4rem; }
.skill-list strong { display: block; margin-bottom: .2rem; }
.muted { color: var(--muted); }

/* ── FOOTER ── */
.footer-card {
  display: grid; grid-template-columns: 1.05fr .95fr; gap: var(--space-6);
  padding: var(--space-8); border-radius: calc(var(--radius-xl) + .25rem);
  background:
    radial-gradient(circle at 0% 0%, var(--accent-soft), transparent 50%),
    linear-gradient(135deg, color-mix(in srgb, var(--accent-soft) 60%, var(--surface)), var(--surface));
  border: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
}
.footer-note { color: var(--muted); font-size: var(--text-sm); margin-top: var(--space-3); }
footer { padding: 0 0 var(--space-16); }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ── Scroll-triggered reveal ── */
[data-animate] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .8s var(--ease-out-quart),
              transform .8s var(--ease-out-quart);
  will-change: opacity, transform;
}
[data-animate="fade"] { transform: none; }
[data-animate="left"] { transform: translateX(-32px); }
[data-animate="right"] { transform: translateX(32px); }
[data-animate="zoom"] { transform: scale(.94); }
[data-animate].visible {
  opacity: 1;
  transform: translate(0, 0) scale(1);
}

/* Staggered cards/quests */
.cards [data-animate], .quest-grid [data-animate] {
  transition-delay: calc(var(--stagger, 0) * 90ms);
}

/* ── Responsive ── */
@media (max-width: 980px) {
  .hero-grid, .about-grid, .skills-wrap, .footer-card { grid-template-columns: 1fr; }
  .cards { grid-template-columns: 1fr 1fr; }
  .quest-grid { grid-template-columns: 1fr 1fr; }
  .hero-panel { padding: .8rem; }
  .hero-panel img { aspect-ratio: auto; }
}
@media (max-width: 680px) {
  .nav { align-items: flex-start; padding: .8rem 0; }
  .nav-links { gap: .8rem; }
  .cards, .quest-grid, .stats { grid-template-columns: 1fr; }
  .hero-actions, .button { width: 100%; }
  h1 { max-width: 100%; }
  .hero-panel { padding: .7rem; }
  .map-note {
    inset: .75rem .75rem auto auto; padding: .4rem .8rem;
    font-size: var(--text-xs); box-shadow: none; border-width: 1px;
  }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
  [data-animate] { opacity: 1 !important; transform: none !important; }
  .word { opacity: 1 !important; transform: none !important; filter: none !important; }
}

/* ── Consent Banner ── */
.consent-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
  padding: var(--space-5) var(--space-6);
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border-top: 1px solid var(--line);
  box-shadow: 0 -8px 40px rgba(0,0,0,.18);
  display: flex; align-items: center; justify-content: center;
  gap: var(--space-6); flex-wrap: wrap;
  animation: slideUp .4s var(--ease-out-quart);
}
.consent-banner[hidden] { display: none; }
.consent-banner p {
  font-size: var(--text-sm); color: var(--muted); max-width: 48rem; margin: 0;
}
.consent-banner p strong { color: var(--text); }
.consent-actions { display: flex; gap: var(--space-3); flex-shrink: 0; }
.consent-actions button {
  padding: .55rem 1.2rem; border-radius: var(--radius-pill);
  font-size: var(--text-sm); font-weight: 600;
  border: 1px solid var(--line);
  transition: transform .15s ease, background .15s ease, box-shadow .2s ease;
}
.consent-actions button:hover { transform: translateY(-1px); }
.consent-accept {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; border-color: transparent;
  box-shadow: 0 4px 16px var(--accent-soft);
}
.consent-accept:hover { box-shadow: 0 8px 24px var(--accent-soft); }
.consent-deny { background: var(--surface); color: var(--text); }
@keyframes slideUp {
  from { transform: translateY(100%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
