*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#6D1B28;
  --teal-dark:#4a1018;
  --teal-mid:#8a2530;
  --teal-light:#e8d5d8;
  --teal-pale:#f7eded;
  --gold:#C5A021;
  --gold-dark:#9c7e16;
  --coral:#ff7058;
  --bg:#FBF9F6;
  --paper:#ffffff;
  --text:#2E1A14;
  --text-muted:#4a2818;
  --text-dim:#6b4530;
  --border:rgba(109,27,40,0.18);
  --serif:'Fraunces',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
}
[data-theme="dark"]{
  --teal:#3eb8a8;
  --teal-dark:#7cf6c2;
  --teal-mid:#2a9d8f;
  --teal-light:#3a6e64;
  --teal-pale:#1a2e2a;
  --gold:#e2c87c;
  --bg:#0a1814;
  --paper:#13241f;
  --text:#f0faf6;
  --text-muted:#a8d0c8;
  --text-dim:#7aa49c;
  --border:rgba(124,246,194,0.22);
}
html,body{
  background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:16px;line-height:1.6;
  min-height:100vh;
  transition:background 0.35s,color 0.35s;
}

.bg-mesh{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0.6;
  background:
    radial-gradient(700px circle at 12% 18%, rgba(255,112,88,0.16), transparent 55%),
    radial-gradient(600px circle at 92% 82%, rgba(197,160,33,0.14), transparent 55%);
}

.cv-back{
  position:sticky;top:0;z-index:10;
  background:color-mix(in srgb,var(--bg) 92%,transparent);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.cv-back a{
  font-size:14px;color:var(--teal-dark);text-decoration:none;font-weight:500;
  display:inline-flex;align-items:center;gap:6px;transition:color 0.25s;
}
.cv-back a:hover,.cv-back a:focus-visible{color:var(--teal);outline:none}
.cv-back-name{font-family:var(--serif);font-size:15px;color:var(--teal-dark);font-weight:500;letter-spacing:0.01em}
.cv-back-actions{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}
.cv-theme-btn{
  font-size:13px;color:var(--text-muted);background:transparent;
  border:1px solid var(--border);
  padding:6px 12px;border-radius:20px;cursor:pointer;font-family:inherit;
  display:inline-flex;align-items:center;gap:6px;
  transition:all 0.25s;
}
.cv-theme-btn:hover,.cv-theme-btn:focus-visible{
  border-color:var(--teal);color:var(--teal);outline:none;
}

main{
  position:relative;z-index:1;
  max-width:1100px;margin:0 auto;
  padding:60px 28px 80px;
}

.hero-eyebrow{
  font-size:12px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--teal);font-weight:500;margin-bottom:14px;
  opacity:0;animation:fadeUp 0.65s cubic-bezier(0.4,0,0.2,1) 0.05s forwards;
}
h1.cv-title{
  font-family:var(--serif);font-size:clamp(36px,5vw,56px);
  line-height:1.1;color:var(--teal-dark);font-weight:500;
  letter-spacing:-0.02em;margin-bottom:16px;
  opacity:0;animation:fadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.15s forwards;
}
h1.cv-title span{color:var(--teal);font-style:italic;font-weight:300}
.cv-sub{
  font-size:17px;color:var(--text-muted);max-width:640px;font-weight:300;line-height:1.65;
  margin-bottom:42px;
  opacity:0;animation:fadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.25s forwards;
}

.cv-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:18px;
}
.cv-card{
  background:var(--paper);
  border:1px solid var(--border);border-radius:14px;
  padding:24px 22px;
  display:flex;flex-direction:column;gap:12px;
  box-shadow:0 4px 20px rgba(10,54,48,0.06);
  position:relative;overflow:hidden;
  opacity:0;animation:fadeUp 0.7s cubic-bezier(0.4,0,0.2,1) forwards;
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1),box-shadow 0.35s,border-color 0.35s;
}
.cv-card::before{
  content:"";position:absolute;left:0;top:0;height:3px;width:100%;
  background:linear-gradient(90deg,var(--teal),var(--gold));
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.5s cubic-bezier(0.4,0,0.2,1);
}
.cv-card:hover,.cv-card:focus-within{
  transform:translateY(-4px);
  box-shadow:0 14px 36px rgba(10,54,48,0.12);
  border-color:var(--teal);
}
.cv-card:hover::before,.cv-card:focus-within::before{transform:scaleX(1)}
.cv-card:nth-child(1){animation-delay:0.35s}
.cv-card:nth-child(2){animation-delay:0.45s}
.cv-card:nth-child(3){animation-delay:0.55s}
.cv-card:nth-child(4){animation-delay:0.65s}
.cv-card:nth-child(5){animation-delay:0.75s}

.cv-card-icon{
  width:46px;height:46px;border-radius:12px;
  background:var(--teal-pale);color:var(--teal-dark);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:500;
  border:1px solid var(--border);
}
.cv-card-role{
  font-family:var(--serif);font-size:22px;color:var(--teal-dark);
  font-weight:500;line-height:1.2;
}
.cv-card-tag{
  font-size:14px;color:var(--text-muted);line-height:1.6;font-weight:300;
  flex-grow:1;
}
.cv-card-pills{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}
.cv-card-pill{
  font-size:11.5px;color:var(--teal-dark);
  background:var(--teal-pale);border:1px solid var(--border);
  padding:3px 10px;border-radius:14px;font-weight:500;
}

.cv-card-actions{
  display:flex;gap:8px;flex-wrap:wrap;margin-top:6px;
}
.cv-card-btn{
  font-size:13.5px;font-weight:500;
  padding:9px 16px;border-radius:22px;
  text-decoration:none;display:inline-flex;align-items:center;gap:6px;
  border:1px solid var(--teal);
  transition:all 0.25s cubic-bezier(0.4,0,0.2,1);
  cursor:pointer;font-family:inherit;
}
.cv-card-btn-primary{
  background:var(--teal);color:#fff;
}
.cv-card-btn-primary:hover,.cv-card-btn-primary:focus-visible{
  background:var(--teal-mid);border-color:var(--teal-mid);
  outline:none;transform:translateY(-1px);
}
.cv-card-btn-ghost{
  background:transparent;color:var(--teal-dark);
}
.cv-card-btn-ghost:hover,.cv-card-btn-ghost:focus-visible{
  background:var(--teal-pale);outline:none;transform:translateY(-1px);
}

.cv-footnote{
  margin-top:48px;font-size:13px;color:var(--text-dim);
  text-align:center;font-weight:300;line-height:1.7;max-width:600px;margin-left:auto;margin-right:auto;
  opacity:0;animation:fadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.95s forwards;
}
.cv-footnote a{color:var(--teal);text-decoration:none;font-weight:500}
.cv-footnote a:hover{text-decoration:underline}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .hero-eyebrow,h1.cv-title,.cv-sub,.cv-card,.cv-footnote{opacity:1}
}
