/* =========================================================
   XIMENA CÓRDOBA — Portafolio
   "Ingeniera + Artista" : precisión de la ingeniería
   + calidez de un estudio de pintura.
   ========================================================= */

:root{
  /* --- Lienzo / papel --- */
  --paper:        #F3ECDF;
  --paper-2:      #EDE3D2;
  --paper-deep:   #E6D9C2;
  --ink:          #241F1A;
  --ink-soft:     #4A423A;
  --ink-faint:    #676051;

  /* --- Paleta de óleos --- */
  --terracotta:   #C5552F;
  --ochre:        #DCA02E;
  --sap:          #4E7B55;
  --cobalt:       #2C5E7E;
  --plum:         #84436A;

  /* tints */
  --terracotta-t: #efd2c5;
  --ochre-t:      #f1e0b6;
  --sap-t:        #cfdcc9;
  --cobalt-t:     #c3d3dc;
  --plum-t:       #ddc5d2;

  --line:         rgba(36,31,26,.16);
  --line-soft:    rgba(36,31,26,.08);

  --serif:  'Bodoni Moda', Georgia, serif;
  --sans:   'Archivo', system-ui, sans-serif;
  --mono:   'Spline Sans Mono', ui-monospace, monospace;

  --maxw: 1280px;
  --gut: clamp(20px, 5vw, 96px);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

/* ---------- DARK THEME ---------- */
html[data-theme="dark"]{
  --paper:        #17130F;
  --paper-2:      #201A15;
  --paper-deep:   #2A231C;
  --ink:          #F1E8DA;
  --ink-soft:     #C2B5A2;
  --ink-faint:    #A09180;
  --line:         rgba(241,232,218,.16);
  --line-soft:    rgba(241,232,218,.08);
}
html[data-theme="dark"] body::before{ opacity:.28; mix-blend-mode:soft-light; }
html[data-theme="dark"] .cv-body{ background:#100D0A; }
html[data-theme="dark"] .adm-body{ background:#100D0A; }

/* theme toggle button */
.theme-tog{
  width:34px; height:34px; flex:none; border-radius:50%;
  border:1px solid var(--line); background:color-mix(in srgb,var(--paper) 60%, transparent);
  display:inline-flex; align-items:center; justify-content:center; color:var(--ink-soft);
  transition:transform .3s var(--ease), color .25s, border-color .25s;
}
.theme-tog:hover{ transform:translateY(-2px) rotate(-12deg); color:var(--ink); border-color:var(--ink-faint); }
.theme-tog svg{ width:17px; height:17px; }

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  overflow-x:hidden;
  position:relative;
}

/* paper grain overlay */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none; z-index:1;
  opacity:.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
}

::selection{ background:var(--ochre); color:var(--ink); }

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }

/* ---------- layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.col-12{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(16px,2.4vw,34px); }

.eyebrow{
  font-family:var(--mono);
  font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-faint);
  display:flex; align-items:center; gap:12px;
}
.eyebrow .num{ color:var(--terracotta); font-weight:600; }
.eyebrow::after{
  content:""; height:1px; flex:1; background:var(--line);
}

.section{ position:relative; padding-block:clamp(72px,11vh,150px); z-index:2; }
.section-title{
  font-family:var(--serif);
  font-weight:500;
  line-height:.98;
  letter-spacing:-.01em;
  font-size:clamp(40px,7vw,86px);
}
.section-title em{ font-style:italic; }
.section-sub{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin-top:16px; }

/* ======================================================
   NAV
   ====================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gut);
  transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
.nav.scrolled{
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:blur(10px);
  box-shadow:0 1px 0 var(--line-soft);
  padding-block:12px;
}
.nav .brand{
  font-family:var(--serif); font-weight:600; font-size:20px; letter-spacing:.01em;
  display:flex; align-items:center; gap:10px;
}
.nav .brand .dab{ width:14px; height:14px; }
.nav-links{ display:flex; gap:26px; align-items:center; }
.nav-links a{
  font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); position:relative; padding:4px 0;
  transition:color .25s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0;
  background:var(--terracotta); transition:width .3s var(--ease);
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ width:100%; }
.nav .cv-btn{
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:8px; padding:8px 16px; border-radius:999px;
  background:var(--ink); color:var(--paper); transition:transform .3s var(--ease), box-shadow .3s;
}
.nav .cv-btn:hover{ transform:translateY(-2px); box-shadow:0 10px 22px -10px rgba(36,31,26,.5); }
.nav .cv-btn::after{ display:none; }

/* language toggle */
.lang{
  display:flex; align-items:center; border:1px solid var(--line);
  border-radius:999px; overflow:hidden; font-family:var(--mono);
  background:color-mix(in srgb,var(--paper) 60%, transparent);
}
.lang button{
  font-size:11px; letter-spacing:.1em; padding:6px 12px; color:var(--ink-faint);
  transition:color .25s;
}
.lang button.on{ color:var(--paper); background:var(--ink); }
.lang button:not(.on):hover{ color:var(--ink); }

.menu-btn{ display:none; }

/* progress brush */
.progress{
  position:fixed; top:0; left:0; height:3px; z-index:60;
  background:linear-gradient(90deg,var(--terracotta),var(--ochre),var(--sap),var(--cobalt),var(--plum));
  width:0%;
}

/* ======================================================
   HERO
   ====================================================== */
.hero{
  min-height:90svh; position:relative; display:flex; align-items:center;
  padding-top:96px; z-index:2; overflow:hidden;
}
.hero .wrap{ width:100%; }
.hero-grid{
  display:grid; grid-template-columns:1.25fr .9fr; gap:clamp(24px,4vw,70px);
  align-items:center;
}
.hero-eyebrow{
  font-family:var(--mono); font-size:13px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-soft); display:flex; gap:14px; align-items:center;
  margin-bottom:26px;
}
.hero h1{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(58px,11.5vw,158px); line-height:.84; letter-spacing:-.025em;
}
.hero h1 .ln{ display:block; overflow:hidden; }
.hero h1 .ln span{ display:block; }
.hero h1 em{ font-style:italic; color:var(--terracotta); }
.hero-role{
  margin-top:30px; font-family:var(--mono); font-size:clamp(12px,1.4vw,15px);
  letter-spacing:.06em; color:var(--ink-soft); display:flex; flex-wrap:wrap; gap:8px 16px;
  align-items:center; line-height:1.5;
}
.hero-role > span{ white-space:nowrap; }
.hero-role .sep{ color:var(--terracotta); }
.hero-lede{
  margin-top:30px; max-width:46ch; font-size:clamp(15px,1.7vw,18.5px);
  color:var(--ink-soft); line-height:1.65; text-wrap:pretty;
}
.hero-cta{ margin-top:38px; display:flex; gap:16px; flex-wrap:wrap; align-items:center; }

.btn{
  display:inline-flex; align-items:center; gap:10px; white-space:nowrap;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.12em; text-transform:uppercase;
  padding:14px 24px; border-radius:999px; transition:transform .3s var(--ease), background .3s, color .3s, box-shadow .3s;
}
.btn-solid{ background:var(--ink); color:var(--paper); }
.btn-solid:hover{ transform:translateY(-3px); box-shadow:0 12px 28px rgba(36,31,26,.22); }
.btn-ghost{ border:1px solid var(--line); }
.btn-ghost:hover{ background:var(--ink); color:var(--paper); transform:translateY(-3px); }

/* portrait */
.portrait-wrap{ position:relative; justify-self:center; }
.portrait{
  width:clamp(240px,30vw,400px); height:clamp(310px,40vw,520px);
  border-radius:200px 200px 14px 14px;
  overflow:hidden; box-shadow:0 30px 60px -28px rgba(36,31,26,.45);
  border:1px solid var(--line);
  position:relative; z-index:2;
  background:linear-gradient(160deg, var(--paper-2), var(--paper-deep));
}
.portrait image-slot{ width:100%; height:100%; }
.portrait-frame{
  position:absolute; inset:-16px; border:1px solid var(--terracotta);
  border-radius:210px 210px 22px 22px; z-index:1; opacity:.55;
}

/* mobile-only circular avatar shown next to the name (desktop keeps the arch portrait) */
.hero-avatar{ display:none; }

/* floating paint dabs */
.dab{ display:inline-block; }
.dab svg{ display:block; width:100%; height:100%; }
.hero-dabs{ position:absolute; inset:0; pointer-events:none; z-index:1; }
.hero-dabs .dab{ position:absolute; filter:drop-shadow(0 8px 18px rgba(36,31,26,.16)); }

.palette-strip{
  display:flex; gap:0; margin-top:42px; align-items:flex-end;
}
.palette-strip .chip{
  height:30px; flex:1; position:relative;
  transition:height .4s var(--ease), flex .4s var(--ease);
}
.palette-strip .chip:first-child{ border-radius:6px 0 0 6px; }
.palette-strip .chip:last-child{ border-radius:0 6px 6px 0; }
.palette-strip .chip .tip{
  position:absolute; bottom:calc(100% + 8px); left:50%; transform:translateX(-50%) translateY(6px);
  font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-soft); white-space:nowrap; opacity:0; transition:opacity .3s, transform .3s; pointer-events:none;
}
.palette-strip .chip:hover{ height:46px; }
.palette-strip .chip:hover .tip{ opacity:1; transform:translateX(-50%) translateY(0); }

.scroll-hint{
  position:absolute; bottom:26px; left:var(--gut); display:flex; align-items:center; gap:12px;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint);
}
.scroll-hint .ln{ width:46px; height:1px; background:var(--ink-faint); position:relative; overflow:hidden; }
.scroll-hint .ln::after{ content:""; position:absolute; inset:0; background:var(--terracotta); animation:slide 2.4s var(--ease) infinite; }
@keyframes slide{ 0%{transform:translateX(-100%)} 60%,100%{transform:translateX(100%)} }

/* ======================================================
   ABOUT
   ====================================================== */
.about-grid{ grid-template-columns:1fr; gap:0; }
.about-lead{
  font-family:var(--serif); font-weight:400; font-size:clamp(26px,4.2vw,52px);
  line-height:1.16; letter-spacing:-.01em; max-width:20ch; text-wrap:balance;
  grid-column:1 / span 12;
}
.about-lead em{ font-style:italic; color:var(--terracotta); }
.about-body{ margin-top:48px; display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(16px,2.4vw,34px); }
.about-body .col{ grid-column:span 6; }
.about-body p{ color:var(--ink-soft); font-size:16.5px; line-height:1.7; max-width:52ch; text-wrap:pretty; }
.about-body p + p{ margin-top:18px; }
.traits{ margin-top:30px; display:flex; flex-wrap:wrap; gap:10px; }
.trait{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.06em;
  padding:8px 14px; border:1px solid var(--line); border-radius:999px; color:var(--ink-soft);
  transition:background .3s, color .3s, border-color .3s, transform .3s;
}
.trait:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); transform:translateY(-2px); }

@media(max-width:820px){ .about-body .col{ grid-column:span 12; } }

/* ======================================================
   EXPERIENCE
   ====================================================== */
.exp-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:60px; }
.exp-head .meta{ font-family:var(--mono); font-size:13px; color:var(--ink-faint); letter-spacing:.06em; text-align:right; }
.exp-list{ border-top:1px solid var(--line); }
.exp{
  border-bottom:1px solid var(--line); padding-block:34px;
  display:grid; grid-template-columns:80px 1.2fr 1.4fr; gap:clamp(16px,3vw,48px);
  align-items:start; position:relative; cursor:pointer;
  transition:background .35s var(--ease);
}
.exp::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--accent,var(--terracotta));
  opacity:.07; transition:width .4s var(--ease); z-index:-1;
}
.exp:hover::before{ width:100%; }
.exp .idx{ font-family:var(--mono); font-size:13px; color:var(--ink-faint); padding-top:7px; display:flex; align-items:center; gap:10px; }
.exp .idx .dot{ width:9px; height:9px; border-radius:50%; background:var(--accent,var(--terracotta)); flex:none; }
.exp .role{ }
.exp .role h3{ font-family:var(--serif); font-weight:500; font-size:clamp(20px,2.4vw,29px); line-height:1.08; letter-spacing:-.01em; }
.exp .role .company{ margin-top:8px; font-size:15px; color:var(--ink-soft); }
.exp .role .dates{ margin-top:10px; font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--ink-faint); display:flex; align-items:center; gap:8px; font-variant-numeric:lining-nums tabular-nums; }
.exp .role .badge{ display:inline-block; margin-top:16px; font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; padding:5px 12px; border-radius:999px; background:var(--accent,var(--terracotta)); color:#fff; }
.exp .detail{ }
.exp .summary{ color:var(--ink-soft); font-size:15.5px; line-height:1.65; text-wrap:pretty; }
.exp .bullets{ list-style:none; margin-top:0; max-height:0; overflow:hidden; transition:max-height .5s var(--ease), margin-top .5s var(--ease); }
.exp.open .bullets{ max-height:760px; margin-top:18px; }
.exp .bullets li{ position:relative; padding-left:22px; font-size:14.5px; color:var(--ink-soft); line-height:1.6; }
.exp .bullets li + li{ margin-top:11px; }
.exp .bullets li::before{ content:""; position:absolute; left:0; top:9px; width:7px; height:7px; border-radius:2px 6px 2px 6px; background:var(--accent,var(--terracotta)); transform:rotate(8deg); }
.exp .toggle{ margin-top:16px; font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent,var(--terracotta)); display:inline-flex; align-items:center; gap:8px; }
.exp .toggle .pm{ width:16px; height:16px; border:1px solid currentColor; border-radius:50%; display:grid; place-items:center; font-size:13px; line-height:1; transition:transform .4s var(--ease); }
.exp.open .toggle .pm{ transform:rotate(135deg); }

@media(max-width:860px){
  .exp{ grid-template-columns:1fr; gap:14px; }
  .exp .idx{ padding-top:0; }
}

/* ======================================================
   SKILLS / DIGITAL
   ====================================================== */
.skills-grid{ display:grid; grid-template-columns:1fr; gap:clamp(28px,4vw,48px); align-items:start; }
.skill-block h4{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:24px; display:flex; align-items:center; gap:10px; }
.skill-block h4 .dab{ width:13px; height:13px; }
.meter{ margin-bottom:22px; }
.meter .top{ display:flex; justify-content:space-between; align-items:baseline; gap:20px; margin-bottom:13px; }
.meter .name{ font-size:16px; font-weight:500; line-height:1.3; }
.meter .lvl{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); white-space:nowrap; flex:none; text-align:right; }
.meter .track{ height:6px; border-radius:999px; background:var(--paper-deep); overflow:hidden; }
.meter .fill{ height:100%; width:0; border-radius:999px; transition:width 1.1s var(--ease-out); }
.tools{ display:flex; flex-wrap:wrap; gap:10px; margin-top:6px; }
.tool{
  font-family:var(--mono); font-size:12px; letter-spacing:.03em; padding:9px 15px; white-space:nowrap;
  border:1px solid var(--line); border-radius:8px; background:color-mix(in srgb,var(--paper-2) 70%, transparent);
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.tool:hover{ transform:translateY(-3px) rotate(-1deg); box-shadow:0 10px 22px -12px rgba(36,31,26,.4); border-color:var(--accent,var(--terracotta)); }

@media(max-width:820px){ .skills-grid{ grid-template-columns:1fr; } }

/* ======================================================
   LANGUAGES
   ====================================================== */
.lang-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,40px); }
.lang-card{
  border:1px solid var(--line); border-radius:18px; padding:34px;
  background:color-mix(in srgb,var(--paper-2) 60%, transparent);
  display:flex; gap:26px; align-items:center; position:relative; overflow:hidden;
  transition:transform .4s var(--ease), box-shadow .4s;
}
.lang-card:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -30px rgba(36,31,26,.45); }
.ring{ position:relative; width:96px; height:96px; flex:none; }
.ring svg{ transform:rotate(-90deg); }
.ring .pct{ position:absolute; inset:0; display:grid; place-items:center; font-family:var(--mono); font-weight:600; font-size:15px; }
.lang-card .info h3{ font-family:var(--serif); font-weight:500; font-size:27px; line-height:1; }
.lang-card .info .sub{ margin-top:8px; font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); }
.lang-card .info p{ margin-top:10px; font-size:14.5px; color:var(--ink-soft); max-width:30ch; }

@media(max-width:680px){ .lang-grid{ grid-template-columns:1fr; } }

/* ======================================================
   EDUCATION
   ====================================================== */
.edu-list{ display:grid; gap:0; border-top:1px solid var(--line); }
.edu{
  display:grid; grid-template-columns:.5fr 1.6fr 1fr; gap:clamp(16px,3vw,40px);
  padding-block:30px; border-bottom:1px solid var(--line); align-items:baseline;
  transition:padding-left .35s var(--ease);
}
.edu:hover{ padding-left:14px; }
.edu .yr{ font-family:var(--mono); font-size:13px; color:var(--accent,var(--terracotta)); letter-spacing:.04em; }
.edu .deg h3{ font-family:var(--serif); font-weight:500; font-size:clamp(20px,2.4vw,28px); line-height:1.1; }
.edu .deg .school{ margin-top:7px; font-size:15px; color:var(--ink-soft); }
.edu .note{ font-family:var(--mono); font-size:12px; color:var(--ink-faint); letter-spacing:.04em; }
/* clickable record (certs with a URL) → opens modal */
.edu.is-link{ width:100%; text-align:left; font:inherit; color:inherit; background:none; border:none; border-bottom:1px solid var(--line); cursor:pointer; }
.rec-view{ display:inline-block; margin-left:10px; color:var(--terracotta); font-family:var(--mono); font-size:11px; letter-spacing:.08em; opacity:0; transform:translateX(-6px); transition:opacity .3s var(--ease), transform .3s var(--ease); }
.edu.is-link:hover .rec-view, .edu.is-link:focus-visible .rec-view{ opacity:1; transform:none; }
@media(hover:none){ .rec-view{ opacity:.85; transform:none; } }

/* certification modal */
.cert-modal{ position:fixed; inset:0; z-index:120; display:flex; align-items:center; justify-content:center; padding:clamp(14px,4vw,40px); background:color-mix(in srgb,#000 55%, transparent); backdrop-filter:blur(4px); animation:certfade .25s var(--ease); }
@keyframes certfade{ from{opacity:0} to{opacity:1} }
.cert-panel{ width:min(940px,100%); max-height:90vh; display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:0 40px 90px -30px rgba(0,0,0,.6); }
.cert-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:16px; padding:18px 22px; border-bottom:1px solid var(--line); }
.cert-t{ font-family:var(--serif); font-weight:500; font-size:20px; line-height:1.2; }
.cert-s{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); margin-top:5px; }
.cert-x{ flex:none; width:40px; height:40px; border-radius:50%; border:1px solid var(--line); color:var(--ink-soft); display:inline-flex; align-items:center; justify-content:center; transition:background .25s, color .25s, border-color .25s; }
.cert-x:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.cert-stage{ flex:1; min-height:0; background:var(--paper-2); display:flex; align-items:center; justify-content:center; position:relative; }
.cert-stage.is-empty{ min-height:260px; }
.cert-stage iframe{ width:100%; height:70vh; border:0; display:block; }
.cert-stage img{ width:100%; height:auto; max-height:78vh; object-fit:contain; }
.cert-empty{ padding:60px 30px; font-family:var(--mono); font-size:13px; line-height:1.7; color:var(--ink-faint); text-align:center; max-width:42ch; }
.cert-help{
  position:absolute; left:18px; right:18px; bottom:18px;
  padding:10px 14px; border:1px solid var(--line); border-radius:999px;
  background:color-mix(in srgb,var(--paper) 88%, transparent); backdrop-filter:blur(8px);
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-faint); text-align:center; pointer-events:none;
}
.cert-foot{ padding:16px 22px; border-top:1px solid var(--line); display:flex; justify-content:flex-end; }
@media(max-width:560px){ .cert-stage iframe{ height:60vh; } }

@media(max-width:760px){ .edu{ grid-template-columns:1fr; gap:8px; } }

/* ======================================================
   HOBBIES STRIP (subtle)
   ====================================================== */
.hobbies{ padding-block:46px; border-block:1px solid var(--line); overflow:hidden; position:relative; z-index:2; background:color-mix(in srgb,var(--paper-deep) 50%, transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.hobbies .label{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-faint); text-align:center; margin-bottom:26px; }
.marquee{ display:flex; gap:0; white-space:nowrap; width:max-content; animation:marq 34s linear infinite; }
.marquee:hover{ animation-play-state:paused; }
.marquee .item{ font-family:var(--serif); font-style:italic; font-size:clamp(26px,4vw,46px); color:var(--ink); display:inline-flex; align-items:center; padding-inline:30px; opacity:.8; }
.marquee .item .dab{ width:18px; height:18px; margin-left:30px; }
@keyframes marq{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ======================================================
   CONTACT / FOOTER
   ====================================================== */
.contact{ position:relative; z-index:2; padding-block:clamp(80px,12vh,150px); }
.contact .big{
  font-family:var(--serif); font-weight:500; font-size:clamp(44px,9vw,128px); line-height:.9; letter-spacing:-.02em;
}
.contact .big em{ font-style:italic; color:var(--terracotta); }
.contact-rows{ margin-top:60px; border-top:1px solid var(--line); max-width:820px; }

/* contact: icon buttons (correo / WhatsApp / LinkedIn) */
.contact-icons{ display:flex; gap:18px; margin-top:50px; flex-wrap:wrap; }
.cicon{ display:inline-flex; flex-direction:column; align-items:center; gap:10px; color:var(--ink-soft); transition:color .3s; }
.cicon svg{
  width:26px; height:26px; padding:14px; box-sizing:content-box;
  border:1px solid var(--line); border-radius:50%;
  background:color-mix(in srgb,var(--paper) 60%, transparent);
  transition:transform .3s var(--ease), background .3s, color .3s, border-color .3s, box-shadow .3s;
}
.cicon:hover{ color:var(--ink); }
.cicon:hover svg{ transform:translateY(-3px); background:var(--ink); color:var(--paper); border-color:var(--ink); box-shadow:0 14px 28px -14px rgba(36,31,26,.55); }
.cicon-cap{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); }
.contact-loc{ margin-top:30px; font-family:var(--mono); font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); display:flex; gap:18px; flex-wrap:wrap; }
.crow{
  display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding-block:24px; border-bottom:1px solid var(--line); position:relative;
  transition:padding-left .35s var(--ease);
}
.crow:hover{ padding-left:14px; }
.crow .k{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); }
.crow .v{ font-size:clamp(17px,2.4vw,26px); font-family:var(--serif); display:flex; align-items:center; gap:14px; white-space:nowrap; font-variant-numeric:lining-nums tabular-nums; }
.crow .k{ flex:none; }
.crow .v .arrow{ opacity:0; transform:translateX(-8px); transition:opacity .3s, transform .3s; color:var(--terracotta); }
.crow:hover .v .arrow{ opacity:1; transform:translateX(0); }

.footer{ padding-block:40px; border-top:1px solid var(--line); display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px; align-items:center; font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; color:var(--ink-faint); position:relative; z-index:2; }
.footer .dabs{ display:flex; gap:6px; }
.footer .dabs span{ width:11px; height:11px; border-radius:50%; }

/* ======================================================
   REVEAL ANIMATIONS
   ====================================================== */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal-d1{ transition-delay:.08s; }
.reveal-d2{ transition-delay:.16s; }
.reveal-d3{ transition-delay:.24s; }
.reveal-d4{ transition-delay:.32s; }

/* hero intro */
.hero h1 .ln span{ transform:translateY(110%); transition:transform 1s var(--ease-out); }
.hero.ready h1 .ln span{ transform:translateY(0); }
.hero .fade{ opacity:0; transform:translateY(20px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.hero.ready .fade{ opacity:1; transform:none; }
.hero .fade.f1{ transition-delay:.5s; }
.hero .fade.f2{ transition-delay:.66s; }
.hero .fade.f3{ transition-delay:.8s; }
.hero .fade.f4{ transition-delay:.94s; }
.hero .portrait-wrap{ opacity:0; transform:scale(.94) translateY(20px); transition:opacity 1.1s var(--ease-out) .3s, transform 1.1s var(--ease-out) .3s; }
.hero.ready .portrait-wrap{ opacity:1; transform:none; }
.hero-dabs .dab{ opacity:0; transform:scale(.4) rotate(-20deg); transition:opacity .9s var(--ease-out), transform 1.1s var(--ease-out); }
.hero.ready .hero-dabs .dab{ opacity:.92; transform:scale(1) rotate(var(--rot,0deg)); }

@media(prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important; }
  .reveal{ opacity:1; transform:none; }
}

/* ======================================================
   RESPONSIVE NAV
   ====================================================== */
@media(max-width:900px){
  .section{ padding-block:clamp(48px,7vh,80px); }

  /* on mobile, replace the big arch portrait with a small circular avatar
     placed to the RIGHT of the name, and compact the hero to remove dead space */
  .hero{ min-height:auto; align-items:flex-start; padding-top:112px; padding-bottom:54px; }
  .scroll-hint{ display:none; }
  .hero-grid{ grid-template-columns:1fr; }
  .portrait-wrap{ display:none; }
  .hero-namerow{ display:flex; align-items:center; gap:14px; }
  /* slightly smaller name on mobile so a larger avatar fits beside it without clipping */
  .hero-namerow h1{ flex:1 1 auto; min-width:0; font-size:clamp(44px,12.5vw,52px); }
  .hero-avatar{
    display:block; flex:none; width:104px; height:104px; border-radius:50%; overflow:hidden;
    border:2px solid var(--paper);
    box-shadow:0 0 0 1.5px var(--terracotta), 0 16px 32px -16px rgba(36,31,26,.4);
    background:linear-gradient(160deg,var(--paper-2),var(--paper-deep));
  }
  .hero-avatar img{ width:100%; height:100%; object-fit:cover; display:block; }
  /* the floating paint dabs were overlapping the text and CTAs on narrow screens */
  .hero-dabs{ display:none; }

  /* hamburger menu: the bar keeps brand + button, everything else drops into a
     panel so nothing overlaps on small screens (the bar used to collide) */
  .menu-btn{
    display:inline-flex; flex-direction:column; justify-content:center; gap:5px;
    width:44px; height:40px; padding:0 11px; border:1px solid var(--line); border-radius:11px;
    background:color-mix(in srgb,var(--paper) 65%, transparent);
  }
  .menu-btn span{ display:block; height:1.6px; width:100%; background:var(--ink); border-radius:2px;
    transition:transform .3s var(--ease), opacity .2s; }
  .nav.menu-open .menu-btn span:nth-child(1){ transform:translateY(6.6px) rotate(45deg); }
  .nav.menu-open .menu-btn span:nth-child(2){ opacity:0; }
  .nav.menu-open .menu-btn span:nth-child(3){ transform:translateY(-6.6px) rotate(-45deg); }

  .nav-links{
    position:absolute; top:calc(100% + 10px); left:var(--gut); right:var(--gut);
    flex-direction:column; align-items:flex-start; gap:18px;
    background:color-mix(in srgb,var(--paper) 97%, transparent); backdrop-filter:blur(10px);
    border:1px solid var(--line); border-radius:16px; padding:24px;
    box-shadow:0 26px 54px -26px rgba(36,31,26,.45);
    opacity:0; transform:translateY(-8px); pointer-events:none;
    transition:opacity .25s var(--ease), transform .25s var(--ease);
  }
  .nav-links.open{ opacity:1; transform:none; pointer-events:auto; }
  .nav-links a{ font-size:14.5px; letter-spacing:.04em; min-height:44px; display:flex; align-items:center; }
  .nav-links a::after{ display:none; }
  .nav .cv-btn{ margin-top:6px; }
  .nav-links .lang{ margin-top:4px; }
  .lang button{ padding:10px 14px; }
  .theme-tog{ width:44px; height:44px; }
  .menu-btn{ height:44px; }
}

@media(max-width:560px){
  .crow{ flex-direction:column; align-items:flex-start; gap:6px; }
  .crow .v{ white-space:normal; overflow-wrap:anywhere; }
  .meter .top{ flex-wrap:wrap; }
}

@media(max-width:380px){
  .hero-avatar{ width:84px; height:84px; }
  .hero-namerow h1{ font-size:clamp(40px,12vw,48px); }
}
