:root{
  --bg:#f7f6f3;
  --surface:#ffffff;
  --text:#11110f;
  --muted:#6b6b67;
  --line:#e6e3df;
  --accent:#6b8f6b;
  --accent-d:#577559;
  --accent-s:rgba(107,143,107,0.08);
  --r:12px;
  --sh-sm:0 1px 6px rgba(16,16,18,0.06);
  --sh-md:0 4px 18px rgba(16,16,18,0.08);
  --max-width:1100px;
  --measure:68ch;
  font-family:'Merriweather', Georgia, serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-size:18px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:5.5rem}
body{margin:0;background:var(--bg);color:var(--text);line-height:1.65;font-weight:400;font-size:1rem;text-rendering:optimizeLegibility}

a{color:var(--accent);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--accent-d)}
a:focus-visible{outline:3px solid color-mix(in srgb, var(--accent) 25%, transparent);outline-offset:3px;border-radius:4px}

figure{margin:0}
img{display:block;max-width:100%;height:auto}

.wrap{max-width:var(--max-width);margin:0 auto;padding:1.25rem}

/* Type hierarchy & rhythm */
h1,h2,h3,h4{font-weight:700;line-height:1.2;letter-spacing:-0.012em;color:var(--text)}
h1{font-size:clamp(1.6rem, 3.6vw, 2.15rem);margin:0 0 2.5rem;line-height:1.12;letter-spacing:-0.018em}
h2{font-size:clamp(1.35rem, 2.8vw, 1.75rem);margin:0 0 .9rem}
h3{font-size:1.125rem;margin:0 0 .5rem;letter-spacing:-0.005em}
p{margin:0 0 1rem;max-width:var(--measure)}
p:last-child,h2:last-child,h3:last-child{margin-bottom:0}
ul,ol{margin:0 0 1rem;padding-left:1.25rem;max-width:var(--measure)}
strong{font-weight:700}

/* Stylized list marker (replaces the old "- item" pattern) */
.fancy-list{list-style:none;padding:0;margin:0 0 1rem;max-width:var(--measure)}
p:has(+ .fancy-list){margin-bottom:.35rem}
.fancy-list li{position:relative;padding-left:1.1rem;margin:.25rem 0;line-height:1.55}
.fancy-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.78em;
  width:.26rem;
  height:.26rem;
  background:transparent;
  border:1px solid var(--accent);
  border-radius:2px;
  box-shadow:0 0 6px color-mix(in srgb, var(--accent) 55%, transparent),0 0 0 2px color-mix(in srgb, var(--accent) 12%, transparent);
  transform:translateY(-50%) rotate(45deg);
}
.fancy-list li + li{margin-top:.3rem}
.list-label{margin:1rem 0 .35rem !important;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--muted)}
.list-label:first-child{margin-top:0 !important}
em{font-style:italic}

.muted{color:var(--muted);font-size:.95rem}

/* Skip link */
.skip{position:absolute;left:0;top:0;transform:translateY(-120%);background:#111;color:#fff;padding:.5rem 1rem;border-radius:6px;z-index:999}
.skip:focus{transform:none}

/* Header */
header{position:fixed;top:0;left:0;right:0;backdrop-filter:blur(10px) saturate(140%);-webkit-backdrop-filter:blur(10px) saturate(140%);background:rgba(247,246,243,0.72);border-bottom:1px solid var(--line);z-index:60}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.75rem;padding-bottom:.75rem}
.brand{display:flex;flex-direction:column;line-height:1.1}
.brand .name{font-size:1.2rem;font-weight:700;letter-spacing:-0.015em}
.brand .role{font-size:.82rem;color:var(--muted);margin-top:4px;letter-spacing:.01em}

nav.desktop{display:none}

/* Mobile menu button */
.menu-btn{width:48px;height:48px;border:0;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer}
.menu-btn .bar{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;position:relative;transition:transform .25s ease,opacity .2s}
.menu-btn .bar::before,.menu-btn .bar::after{content:'';position:absolute;left:0;right:0;height:2px;background:var(--text);border-radius:2px}
.menu-btn .bar::before{top:-7px}
.menu-btn .bar::after{top:7px}
.menu-btn[aria-expanded="true"] .bar{background:transparent}
.menu-btn[aria-expanded="true"] .bar::before{transform:translateY(7px) rotate(45deg)}
.menu-btn[aria-expanded="true"] .bar::after{transform:translateY(-7px) rotate(-45deg)}

/* Mobile overlay */
.menu-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(239,243,238,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:80}
.menu-overlay[data-open="true"]{display:flex}
.menu-list{list-style:none;padding:2rem;text-align:center;margin:0}
.menu-list li{margin:0}
.menu-list a{display:block;font-size:1.5rem;font-weight:300;padding:.75rem 0;color:var(--text);letter-spacing:-0.01em}
.menu-list a.btn{display:inline-flex;height:auto;padding:.75rem 1.5rem;font-size:1.4rem;font-weight:700;color:#fff;margin-top:.75rem;border-radius:8px}

body{padding-top:4.8rem}
main{padding:0 0 2rem}

/* Buttons & form controls */
.btn{-webkit-appearance:none;appearance:none;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;border-radius:8px;padding:0 1rem;height:40px;min-height:0;border:1px solid transparent;font-weight:700;font-family:inherit;font-size:.95rem;line-height:1;letter-spacing:.005em;transition:background-color .15s ease,color .15s ease,box-shadow .15s ease,transform .05s ease}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-d);color:#fff}
.btn.primary:active{transform:translateY(1px)}

input,textarea,select,button{font-family:inherit;font-size:1rem;color:inherit}
input,textarea,select{width:100%;padding:.7rem .8rem;margin:.35rem 0 .9rem;border:1px solid var(--line);border-radius:8px;background:#fff;line-height:1.5;transition:border-color .15s ease,box-shadow .15s ease}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent)}
textarea{resize:vertical;min-height:120px}
label{display:block;font-size:.92rem;font-weight:700;color:var(--text);letter-spacing:.005em}

/* Floating WhatsApp */
.btn.wapp{position:fixed;bottom:24px;right:24px;z-index:1000;width:52px;height:52px;padding:0;border-radius:50%;background:var(--accent);box-shadow:var(--sh-md)}
.btn.wapp:hover{background:var(--accent-d)}
.btn.wapp svg{width:24px;height:24px}
.btn.wapp img{width:26px;height:26px;display:block}

/* Icon-only buttons (phone, SMS, WhatsApp) */
.icon-btn{padding:0;width:44px;justify-content:center;color:#fff}
.icon-btn svg{width:20px;height:20px;display:block;stroke:currentColor;fill:none}
.icon-btn img{width:20px;height:20px;display:block}

/* Hero */
.hero{display:grid;grid-template-columns:1fr;gap:1.25rem;align-items:start;margin-top:.5rem}
.hero-copy{display:grid;gap:1rem}
.hero-right{grid-column:1}
.hero-portrait{width:100%;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-sm)}
.hero-portrait img{object-fit:cover}
.hero-aside,.hero-aside.card{background:var(--accent-s);padding:1.5rem;border-radius:var(--r);border:1px solid var(--line);box-shadow:none}
.hero-aside p{max-width:none}
.hero-aside h3{margin-top:.25rem}

/* Sections */
section{margin:2.5rem 0;scroll-margin-top:6rem}
section + section{margin-top:3rem}

/* Cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;box-shadow:var(--sh-sm)}
.card > :first-child{margin-top:0}
.card > :last-child{margin-bottom:0}

/* About */
.grid{display:grid;gap:1.25rem}
.sobre-stack{display:grid;gap:1.25rem}
/* Bio section: image floats so text wraps and continues below it */
.experience-image{float:right;width:min(48%,300px);aspect-ratio:1198/965;margin:.25rem 0 1rem 1.5rem;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden;shape-outside:margin-box}
.experience-image img{display:block;width:100%;height:100%;object-fit:cover}

/* Newspaper-style typography for the bio section */
#sobre p{text-align:justify;text-justify:inter-word;hyphens:none;-webkit-hyphens:none;text-wrap:pretty;max-width:none}

/* Standalone sub-section label (eyebrow) */
.label{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700;margin:0 0 .35rem}

/* Tagline / lede line at the top of a card */
.lede{font-size:1.05rem;font-weight:400;color:var(--text);margin:0 0 .75rem}

/* FAQ */
#faq h3{margin:1.25rem 0 .25rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700}
#faq h3:first-of-type{margin-top:0}
details{border-radius:var(--r);background:var(--surface);border:1px solid var(--line);padding:.25rem .625rem;box-shadow:var(--sh-sm);transition:border-color .15s ease}
details[open]{border-color:color-mix(in srgb, var(--accent) 30%, var(--line))}
summary{list-style:none;cursor:pointer;padding:.85rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-weight:400;letter-spacing:-0.005em}
summary::-webkit-details-marker{display:none}
summary::after{content:'+';font-weight:400;font-size:1.4rem;line-height:1;color:var(--accent);flex-shrink:0;transition:transform .2s ease}
details[open] summary::after{content:'\2212'}
details > .muted{padding:.85rem 0 1rem;border-top:1px solid var(--line)}
details[open]{padding-bottom:.625rem}
details > .muted > p:first-child{margin-top:0}
details ul{margin-top:.25rem}

/* Contact */
#contacto > p,
#contacto .muted{max-width:none}
#contacto form .btn{margin-top:.25rem}
.gmiframe{height:10rem;width:100%;max-width:18rem;border-radius:8px;margin-top:.5rem;border:0}
/* Contact aside list (no bullets, tighter rhythm) */
.contact-list{list-style:none;padding:0;margin:0;max-width:none}
.contact-list li{margin:.5rem 0;line-height:1.5}
.contact-list li:first-child{margin-top:.75rem}
.contact-list li:last-child{margin-bottom:0}
.contact-actions{display:inline-flex;gap:.4rem;margin-top:.5rem}
.contact-list .contact-actions{display:flex}

/* Decorative horizontal rule */
hr.flourish{
  border:0;
  height:1px;
  width:min(100%, 280px);
  margin:3rem auto 2.25rem;
  justify-self:center;
  background:linear-gradient(to right, transparent, color-mix(in srgb, var(--accent) 55%, transparent), transparent);
  position:relative;
  overflow:visible;
}
/* Compensate for parent grid gap so visible spacing around the hr matches
   the top-level (margin-collapsed) case. */
.sobre-stack > hr.flourish{margin:1.75rem auto 1rem}
hr.flourish::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:.45rem;
  height:.45rem;
  background:var(--bg);
  border:1px solid var(--accent);
  border-radius:1px;
  transform:translate(-50%,-50%) rotate(45deg);
  box-shadow:0 0 6px color-mix(in srgb, var(--accent) 55%, transparent),0 0 0 2px color-mix(in srgb, var(--accent) 12%, transparent);
}
@media(min-width:780px){
  hr.flourish{margin:4rem auto 4rem;width:min(100%, 340px)}
  .sobre-stack > hr.flourish{margin:2.25rem auto 2.25rem}
}

/* Footer */
footer{padding:2rem 0;color:var(--muted);font-size:.9rem;border-top:1px solid var(--line);margin-top:2rem}
footer a{color:var(--muted)}
footer a:hover{color:var(--text)}

/* Desktop */
@media(min-width:780px){
  body{padding-top:5.2rem}
  .wrap{padding:2rem}
  main{padding:0 0 3rem}

  nav.desktop{display:block}
  .menu-btn{display:none}
  .header-inner{align-items:center;padding-top:.85rem;padding-bottom:.85rem}
  nav.desktop ul{display:flex;gap:.25rem;list-style:none;padding:0;margin:0;align-items:stretch}
  nav.desktop li{display:flex;align-items:stretch}
  nav.desktop a{display:inline-flex;align-items:center;height:40px;color:var(--text);padding:0 .85rem;border-radius:8px;font-size:.95rem;line-height:1;letter-spacing:.005em;transition:background .15s ease;vertical-align:middle}
  nav.desktop a:not(.btn):hover{background:var(--accent-s)}
  nav.desktop .btn{margin-left:.5rem;padding:0 1rem;min-height:0;height:40px;line-height:1}

  .hero{grid-template-columns:minmax(0,1fr) minmax(220px,340px);gap:1.75rem;margin-top:1rem}
  .hero-copy{grid-column:1/2;grid-row:1;display:grid;gap:1.25rem;align-content:start}
  .hero-right{grid-column:2/3;grid-row:1;align-self:stretch;display:flex;justify-content:center}
  .hero-right .hero-portrait{height:100%;max-width:320px;width:100%}
  .hero-right .hero-portrait img{width:100%;height:100%;object-fit:cover}

  section{margin:3.5rem 0}
  section + section{margin-top:4rem}
  .card{padding:1.75rem 2rem}
  .hero-aside,.hero-aside.card{padding:1.75rem 2rem}
  details{padding:.25rem 1rem}
  .sobre-stack{gap:1.75rem}
  #faq .grid{gap:.6rem}

  .contact-grid{grid-template-columns:minmax(0,1.1fr) minmax(0,.8fr);align-items:stretch}
  .contact-grid > .card{height:100%;display:flex;flex-direction:column}
  .contact-grid form.card{display:flex;flex-direction:column}
  .contact-grid form.card textarea{flex:1 1 auto}
  .contact-grid aside.card .gmiframe{max-width:100%;width:100%}
  .gmiframe{max-width:100%;height:12rem}
}

@media(min-width:1100px){
  .card{padding:2rem 2.25rem}
  .hero-aside,.hero-aside.card{padding:2rem 2.25rem}
  details{padding:.25rem 1.125rem}
}

@media(max-width:779px){
  :root{font-size:17px}
  .card{padding:1.25rem}
  .hero-aside,.hero-aside.card{padding:1.25rem}
  .btn.wapp{bottom:18px;right:18px;width:48px;height:48px}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}
