/* ══════════════════════════════════════════════════════════
   RAÍZ — Brand CSS
   Colors from Manual de Identidad Gráfica © 2022 Región Raíz
   Fonts: Bebas Neue (display) + Montserrat (body)
   ══════════════════════════════════════════════════════════ */
@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Montserrat:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap");

:root {
  --cyan:    #05F2F2;
  --coral:   #F28972;
  --yellow:  #F2BE22;
  --sand:    #F2CC85;
  --mint:    #49F2C2;
  --teal-b:  #05F2AF;
  --light:   #F2F2F2;
  --black:   #000000;
  --deep:    #013A40;
  --darkest: #000C0D;
  --forest:  #025940;
  --rust:    #59281D;
  --page:    #EEF6F6;
  --surface: #FFFFFF;
  --surface-2: #DDE9EA;
  --ink-dark:  #0D2B2E;
  --ink-mid:   #3D6166;
  --ink-faint: #7AA5AA;
}

@font-face {
  font-family: 'MyBrushFont';  
  src: url('../css/fonts/Personal_Services.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;           /* shows fallback font while loading */
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
body{font-family:'Montserrat',sans-serif;background:var(--page);color:var(--ink-dark);min-height:100vh;display:flex;flex-direction:column;line-height:1.5;}
img,video,svg{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:inherit;}
button,input,textarea,select{font:inherit;}
ul,ol{list-style:none;}
::selection{background:var(--cyan);color:var(--deep);}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--page);}
::-webkit-scrollbar-thumb{background:var(--ink-faint);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--deep);}

/* ── Font ── */
.font-brush{font-family:'MyBrushFont',cursive;letter-spacing:0.06em;}

/* ── Topo background ── */
.topo-bg{position:relative;overflow:hidden;background:var(--page);}
.topo-bg::before{
  content:"";position:absolute;inset:-8%;width:116%;height:116%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='800' height='600'%3E%3Cdefs%3E%3Cstyle%3Epath%7Bfill:none;stroke:%23013A40;stroke-width:0.7%7D%3C/style%3E%3C/defs%3E%3Cpath opacity='.15' d='M-50,300 Q100,250 200,300 Q300,350 400,300 Q500,250 600,300 Q700,350 850,300'/%3E%3Cpath opacity='.15' d='M-50,340 Q100,290 200,340 Q300,390 400,340 Q500,290 600,340 Q700,390 850,340'/%3E%3Cpath opacity='.15' d='M-50,380 Q100,330 200,380 Q300,430 400,380 Q500,330 600,380 Q700,430 850,380'/%3E%3Cpath opacity='.12' d='M-50,260 Q100,210 200,260 Q300,310 400,260 Q500,210 600,260 Q700,310 850,260'/%3E%3Cpath opacity='.12' d='M-50,220 Q100,170 200,220 Q300,270 400,220 Q500,170 600,220 Q700,270 850,220'/%3E%3Cpath opacity='.1' d='M-50,180 Q100,130 200,180 Q300,230 400,180 Q500,130 600,180 Q700,230 850,180'/%3E%3Cpath opacity='.1' d='M-50,140 Q100,90 200,140 Q300,190 400,140 Q500,90 600,140 Q700,190 850,140'/%3E%3Cpath opacity='.15' d='M-50,420 Q100,370 200,420 Q300,470 400,420 Q500,370 600,420 Q700,470 850,420'/%3E%3Cpath opacity='.12' d='M-50,460 Q100,410 200,460 Q300,510 400,460 Q500,410 600,460 Q700,510 850,460'/%3E%3Cpath opacity='.1' d='M-50,500 Q100,450 200,500 Q300,550 400,500 Q500,450 600,500 Q700,550 850,500'/%3E%3Cpath opacity='.1' d='M100,0 Q150,100 100,200 Q50,300 100,400 Q150,500 100,600'/%3E%3Cpath opacity='.1' d='M300,0 Q350,100 300,200 Q250,300 300,400 Q350,500 300,600'/%3E%3Cpath opacity='.1' d='M500,0 Q550,100 500,200 Q450,300 500,400 Q550,500 500,600'/%3E%3Cpath opacity='.1' d='M700,0 Q750,100 700,200 Q650,300 700,400 Q750,500 700,600'/%3E%3C/svg%3E");
  background-size:800px 600px;background-repeat:repeat;
  animation:grain-drift 18s ease-in-out infinite;pointer-events:none;z-index:0;
}
.topo-content{position:relative;z-index:1;}

.topo-dark{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--darkest) 0%,var(--deep) 60%,#01201f 100%);color:#fff;}
.topo-dark::before{
  content:"";position:absolute;inset:-8%;width:116%;height:116%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='800' height='600'%3E%3Cdefs%3E%3Cstyle%3Epath%7Bfill:none;stroke:%2305F2F2;stroke-width:0.6%7D%3C/style%3E%3C/defs%3E%3Cpath opacity='.15' d='M-50,300 Q100,250 200,300 Q300,350 400,300 Q500,250 600,300 Q700,350 850,300'/%3E%3Cpath opacity='.12' d='M-50,340 Q100,290 200,340 Q300,390 400,340 Q500,290 600,340 Q700,390 850,340'/%3E%3Cpath opacity='.1' d='M-50,380 Q100,330 200,380 Q300,430 400,380 Q500,330 600,380 Q700,430 850,380'/%3E%3Cpath opacity='.12' d='M-50,260 Q100,210 200,260 Q300,310 400,260 Q500,210 600,260 Q700,310 850,260'/%3E%3Cpath opacity='.1' d='M-50,220 Q100,170 200,220 Q300,270 400,220 Q500,170 600,220 Q700,270 850,220'/%3E%3Cpath opacity='.1' d='M100,0 Q150,100 100,200 Q50,300 100,400 Q150,500 100,600'/%3E%3Cpath opacity='.08' d='M400,0 Q450,100 400,200 Q350,300 400,400 Q450,500 400,600'/%3E%3Cpath opacity='.08' d='M700,0 Q750,100 700,200 Q650,300 700,400 Q750,500 700,600'/%3E%3C/svg%3E");
  background-size:800px 600px;background-repeat:repeat;
  animation:grain-drift 18s ease-in-out infinite;pointer-events:none;z-index:0;
}

@keyframes grain-drift{
  0%{transform:translate(0,0);}25%{transform:translate(-1.2%,-1.8%);}
  50%{transform:translate(1.5%,1.2%);}75%{transform:translate(-.8%,2.2%);}100%{transform:translate(0,0);}
}

/* ── Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.animate-fade-up  {animation:fadeUp 0.65s ease both;}
.animate-fade-up-2{animation:fadeUp 0.65s 0.12s ease both;}
.animate-fade-up-3{animation:fadeUp 0.65s 0.24s ease both;}
.animate-fade-up-4{animation:fadeUp 0.65s 0.36s ease both;}
.animate-fade-up-5{animation:fadeUp 0.65s 0.48s ease both;}
.animate-fade-up-6{animation:fadeUp 0.65s 0.60s ease both;}

/* ── Blob ── */
.blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;}

/* ── Header ── */
header{position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(1,58,64,.1);background:rgba(238,246,246,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
.header-inner{max-width:72rem;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:4rem;}
.logo{font-family:'Bebas Neue',cursive;font-size:1.6rem;letter-spacing:.08em;color:var(--deep);transition:color .2s;}
.logo:hover{color:var(--ink-mid);}
.logo-accent{color:var(--coral);}
.nav-desktop{display:none;align-items:center;gap:2rem;}
.nav-link{position:relative;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-mid);transition:color .2s;}
.nav-link::after{content:"";position:absolute;bottom:-4px;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--coral),var(--yellow));border-radius:2px;transition:width .2s;}
.nav-link:hover,.nav-link.active{color:var(--deep);}
.nav-link:hover::after,.nav-link.active::after{width:100%;}
.lang-pair{display:flex;align-items:center;gap:.15rem;font-size:.65rem;font-weight:700;letter-spacing:.08em;}
.lang-btn{padding:.18rem .45rem;border-radius:4px;cursor:pointer;color:var(--ink-faint);transition:all .2s;background:none;border:none;}
.lang-btn.active{color:var(--deep);background:rgba(1,58,64,.08);}
.lang-btn:hover{color:var(--deep);}
.lang-sep{color:var(--ink-faint);opacity:.4;font-size:.6rem;}
.ham{display:flex;flex-direction:column;gap:5px;padding:.5rem;background:none;border:none;cursor:pointer;}
.ham span{display:block;width:22px;height:2px;background:var(--ink-dark);border-radius:2px;transition:all .3s ease;}
.ham.open span:first-child{transform:translateY(7px) rotate(45deg);}
.ham.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.ham.open span:last-child{transform:translateY(-7px) rotate(-45deg);}
#mobile-nav{max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease;border-top:1px solid rgba(1,58,64,.1);}
#mobile-nav.open{max-height:500px;opacity:1;}
.mobile-nav-inner{max-width:72rem;margin:0 auto;padding:1rem;display:flex;flex-direction:column;gap:.25rem;}
.mobile-nav-link{display:block;padding:.75rem .5rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-mid);border-bottom:1px solid rgba(1,58,64,.07);transition:color .2s;}
.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--deep);}
.mobile-lang-row{display:flex;gap:.5rem;padding:.75rem .5rem;align-items:center;}

/* ── Buttons ── */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:9999px;background:var(--cyan);color:var(--deep);padding:.875rem 2rem;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:all .2s;border:none;cursor:pointer;}
.btn-primary:hover{background:var(--mint);transform:translateY(-2px);box-shadow:0 8px 24px rgba(5,242,242,.35);}
.btn-coral{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:9999px;background:var(--coral);color:var(--darkest);padding:.875rem 2rem;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:all .2s;border:none;cursor:pointer;}
.btn-coral:hover{background:var(--sand);transform:translateY(-2px);box-shadow:0 8px 24px rgba(242,137,114,.35);}
.btn-yellow{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:9999px;background:var(--yellow);color:var(--darkest);padding:.875rem 2rem;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:all .2s;border:none;cursor:pointer;}
.btn-yellow:hover{background:var(--coral);transform:translateY(-2px);}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:9999px;border:2px solid var(--deep);color:var(--deep);background:transparent;padding:.75rem 1.75rem;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:all .2s;cursor:pointer;}
.btn-outline:hover{background:var(--deep);color:var(--cyan);}
.btn-outline-light{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:9999px;border:2px solid rgba(5,242,242,.4);color:var(--cyan);background:transparent;padding:.75rem 1.75rem;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:all .2s;cursor:pointer;}
.btn-outline-light:hover{background:var(--cyan);color:var(--deep);}

/* ── Eyebrows ── */
.eyebrow      {font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--cyan);}
.eyebrow-coral{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:#b84a30;}
.eyebrow-yellow{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:#8a6200;}
.eyebrow-mint {font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--forest);}
.eyebrow-white{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:rgba(242,242,242,.6);}

/* ── Badges ── */
.badge       {display:inline-block;padding:.22rem .8rem;border-radius:9999px;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(5,242,242,.15);color:var(--deep);border:1px solid rgba(5,242,242,.3);}
.badge-coral {display:inline-block;padding:.22rem .8rem;border-radius:9999px;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(242,137,114,.15);color:#7a2b1a;border:1px solid rgba(242,137,114,.4);}
.badge-yellow{display:inline-block;padding:.22rem .8rem;border-radius:9999px;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(242,190,34,.15);color:#7a5800;border:1px solid rgba(242,190,34,.4);}
.badge-mint  {display:inline-block;padding:.22rem .8rem;border-radius:9999px;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(73,242,194,.15);color:var(--forest);border:1px solid rgba(73,242,194,.4);}
.badge-white {display:inline-block;padding:.22rem .8rem;border-radius:9999px;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);}

/* ── Cards ── */
.card{overflow:hidden;border-radius:1rem;border:1px solid rgba(1,58,64,.1);background:var(--surface);transition:all .3s ease;box-shadow:0 2px 12px rgba(13,43,46,.07);}
.card:hover{transform:translateY(-4px);border-color:rgba(242,137,114,.3);box-shadow:0 16px 48px rgba(242,137,114,.12);}
.card:hover .card-img{transform:scale(1.05);}
.card:hover .card-title{color:var(--deep);}
.card-img{transition:transform .5s ease;}
.card-placeholder{display:flex;height:100%;width:100%;align-items:flex-end;background:linear-gradient(135deg,var(--surface-2),#c8dee0);padding:1rem;}
.card-bar-cyan  {height:3px;background:linear-gradient(90deg,var(--cyan),var(--mint));}
.card-bar-coral {height:3px;background:linear-gradient(90deg,var(--coral),var(--sand));}
.card-bar-yellow{height:3px;background:linear-gradient(90deg,var(--yellow),var(--coral));}
.card-bar-mint  {height:3px;background:linear-gradient(90deg,var(--mint),var(--teal-b));}
.arrow{display:inline-block;transition:transform .2s;}
.card:hover .arrow{transform:translateX(4px);}

/* ── Forms ── */
.form-input{width:100%;border-radius:.75rem;border:1px solid rgba(1,58,64,.15);background:var(--surface);padding:.875rem 1.25rem;font-family:'Montserrat',sans-serif;font-size:.875rem;color:var(--ink-dark);outline:none;transition:all .2s;}
.form-input::placeholder{color:var(--ink-faint);}
.form-input:focus{border-color:var(--deep);box-shadow:0 0 0 3px rgba(1,58,64,.1);}
textarea.form-input{resize:vertical;}

/* ── Footer ── */
footer{border-top:1px solid rgba(1,58,64,.1);}
.section-divider{border:none;border-top:1px solid rgba(1,58,64,.1);margin:3.5rem 0;}

/* ── Social buttons ── */
.social-btn{width:2.25rem;height:2.25rem;border-radius:50%;border:1px solid rgba(1,58,64,.15);display:inline-flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:var(--ink-mid);transition:all .2s;}
.social-btn:hover{border-color:var(--deep);color:var(--deep);background:rgba(1,58,64,.05);}
.social-btn-light{width:2.25rem;height:2.25rem;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:inline-flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:rgba(255,255,255,.6);transition:all .2s;}
.social-btn-light:hover{border-color:var(--cyan);color:var(--cyan);}

/* ── Event card ── */
.event-card{display:flex;gap:1.25rem;padding:1.25rem 1.5rem;border-radius:1rem;border:1px solid rgba(1,58,64,.1);background:var(--surface);transition:all .3s;box-shadow:0 2px 8px rgba(13,43,46,.05);}
.event-card:hover{transform:translateY(-2px);border-color:rgba(5,242,242,.3);box-shadow:0 8px 32px rgba(5,242,242,.1);}
.event-date-block{flex-shrink:0;width:3.5rem;text-align:center;padding:.5rem .25rem;border-radius:.5rem;background:linear-gradient(135deg,var(--deep),var(--forest));}
.event-day{font-family:'Bebas Neue',cursive;font-size:1.75rem;line-height:1;color:var(--cyan);letter-spacing:.05em;}
.event-month{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:rgba(242,242,242,.6);margin-top:.1rem;}

/* ── Stat block ── */
.stat-block{text-align:center;padding:1.5rem;}
.stat-number{font-family:'Bebas Neue',cursive;font-size:clamp(2.5rem,5vw,4rem);letter-spacing:.05em;line-height:1;}
.stat-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;opacity:.7;margin-top:.4rem;}

/* ── Gradient text ── */
.text-gradient{background:linear-gradient(90deg,var(--coral),var(--yellow),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.text-gradient-warm{background:linear-gradient(90deg,var(--coral),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.text-gradient-cool{background:linear-gradient(90deg,var(--cyan),var(--mint));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

/* ── Nav ── */
@media(min-width:768px){.nav-desktop{display:flex;}.ham{display:none;}}

/* ── Prose ── */
.prose{color:var(--ink-mid);line-height:1.85;font-size:1.05rem;}
.prose h2{font-family:'Bebas Neue',cursive;font-size:2rem;color:var(--deep);margin:2.5rem 0 .8rem;letter-spacing:.05em;}
.prose h3{font-family:'Bebas Neue',cursive;font-size:1.5rem;color:var(--deep);margin:2rem 0 .6rem;letter-spacing:.05em;}
.prose p{margin-bottom:1.5rem;}
.prose a{color:var(--deep);text-decoration:underline;text-underline-offset:3px;}
.prose a:hover{color:var(--teal-b);}
.prose strong{color:var(--ink-dark);font-weight:700;}
.prose ul{list-style:disc;padding-left:1.4rem;margin-bottom:1.5rem;}
.prose li{margin-bottom:.4rem;}
.prose blockquote{border-left:3px solid var(--coral);padding-left:1.4rem;margin:2rem 0;color:var(--rust);font-style:italic;font-size:1.1rem;}
.prose hr{border:none;border-top:1px solid rgba(1,58,64,.12);margin:3rem 0;}

/* ── LAYOUT HELPERS ── */
.container{max-width:72rem;margin:0 auto;padding:0 1rem;}
@media(min-width:640px){.container{padding:0 1.5rem;}.header-inner{padding:0 1.5rem;}}
.flex{display:flex;}.grid{display:grid;}.block{display:block;}.inline-flex{display:inline-flex;}.inline-block{display:inline-block;}
.hidden{display:none;}.relative{position:relative;}.absolute{position:absolute;}.sticky{position:sticky;}
.overflow-hidden{overflow:hidden;}.z-10{z-index:10;}.z-50{z-index:50;}
.items-center{align-items:center;}.items-start{align-items:flex-start;}.items-end{align-items:flex-end;}
.justify-center{justify-content:center;}.justify-between{justify-content:space-between;}.justify-end{justify-content:flex-end;}
.flex-col{flex-direction:column;}.flex-row{flex-direction:row;}.flex-wrap{flex-wrap:wrap;}
.flex-1{flex:1 1 0%;}.flex-shrink-0{flex-shrink:0;}
.self-start{align-self:flex-start;}.mt-auto{margin-top:auto;}
.gap-1{gap:.25rem;}.gap-2{gap:.5rem;}.gap-2_5{gap:.625rem;}.gap-3{gap:.75rem;}.gap-4{gap:1rem;}.gap-5{gap:1.25rem;}.gap-6{gap:1.5rem;}.gap-8{gap:2rem;}.gap-10{gap:2.5rem;}.gap-12{gap:3rem;}.gap-16{gap:4rem;}
.text-center{text-align:center;}.text-left{text-align:left;}.text-right{text-align:right;}
.mx-auto{margin:0 auto;}
.mb-1{margin-bottom:.25rem;}.mb-2{margin-bottom:.5rem;}.mb-3{margin-bottom:.75rem;}.mb-4{margin-bottom:1rem;}.mb-5{margin-bottom:1.25rem;}.mb-6{margin-bottom:1.5rem;}.mb-7{margin-bottom:1.75rem;}.mb-8{margin-bottom:2rem;}.mb-10{margin-bottom:2.5rem;}.mb-12{margin-bottom:3rem;}
.mt-2{margin-top:.5rem;}.mt-4{margin-top:1rem;}.mt-6{margin-top:1.5rem;}.mt-8{margin-top:2rem;}
.pt-4{padding-top:1rem;}.pt-6{padding-top:1.5rem;}.pt-8{padding-top:2rem;}.pt-12{padding-top:3rem;}.pt-16{padding-top:4rem;}.pt-20{padding-top:5rem;}
.pb-4{padding-bottom:1rem;}.pb-6{padding-bottom:1.5rem;}.pb-8{padding-bottom:2rem;}.pb-12{padding-bottom:3rem;}.pb-16{padding-bottom:4rem;}.pb-20{padding-bottom:5rem;}.pb-24{padding-bottom:6rem;}
.py-2{padding-top:.5rem;padding-bottom:.5rem;}.py-3{padding-top:.75rem;padding-bottom:.75rem;}.py-4{padding-top:1rem;padding-bottom:1rem;}.py-5{padding-top:1.25rem;padding-bottom:1.25rem;}.py-6{padding-top:1.5rem;padding-bottom:1.5rem;}.py-8{padding-top:2rem;padding-bottom:2rem;}.py-12{padding-top:3rem;padding-bottom:3rem;}.py-16{padding-top:4rem;padding-bottom:4rem;}.py-20{padding-top:5rem;padding-bottom:5rem;}.py-24{padding-top:6rem;padding-bottom:6rem;}
.px-2{padding-left:.5rem;padding-right:.5rem;}.px-4{padding-left:1rem;padding-right:1rem;}.px-5{padding-left:1.25rem;padding-right:1.25rem;}.px-6{padding-left:1.5rem;padding-right:1.5rem;}
.p-2{padding:.5rem;}.p-4{padding:1rem;}.p-5{padding:1.25rem;}.p-6{padding:1.5rem;}.p-8{padding:2rem;}
.w-full{width:100%;}.h-full{height:100%;}.w-9{width:2.25rem;}.h-9{height:2.25rem;}.w-10{width:2.5rem;}.h-10{height:2.5rem;}.w-14{width:3.5rem;}.h-14{height:3.5rem;}
.max-w-lg{max-width:32rem;}.max-w-2xl{max-width:42rem;}.max-w-3xl{max-width:48rem;}.max-w-5xl{max-width:64rem;}.max-w-6xl{max-width:72rem;}
.min-h-56{min-height:14rem;}.min-h-88{min-height:22rem;}
.aspect-video{aspect-ratio:16/9;}.aspect-square{aspect-ratio:1/1;}.aspect-3-4{aspect-ratio:3/4;}
.rounded-full{border-radius:9999px;}.rounded-xl{border-radius:.75rem;}.rounded-2xl{border-radius:1rem;}.rounded-3xl{border-radius:1.5rem;}
.border{border-width:1px;border-style:solid;border-color:rgba(1,58,64,.1);}.border-b{border-bottom:1px solid rgba(1,58,64,.1);}.border-t{border-top:1px solid rgba(1,58,64,.1);}
.font-bold{font-weight:700;}.font-extrabold{font-weight:800;}.font-semibold{font-weight:600;}
.text-xs{font-size:.75rem;line-height:1rem;}.text-sm{font-size:.875rem;line-height:1.25rem;}.text-base{font-size:1rem;}.text-xl{font-size:1.25rem;line-height:1.75rem;}.text-2xl{font-size:1.5rem;line-height:2rem;}.text-3xl{font-size:1.875rem;line-height:2.25rem;}.text-4xl{font-size:2.25rem;}.text-5xl{font-size:3rem;}
.leading-tight{line-height:1.25;}.leading-relaxed{line-height:1.625;}.leading-none{line-height:1;}
.uppercase{text-transform:uppercase;}.tracking-wide{letter-spacing:.05em;}.tracking-wider{letter-spacing:.1em;}.tracking-widest{letter-spacing:.18em;}
.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;}
.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;}
.opacity-0{opacity:0;}.opacity-50{opacity:.5;}.opacity-60{opacity:.6;}.opacity-70{opacity:.7;}
.select-none{user-select:none;}.whitespace-nowrap{white-space:nowrap;}
.transition-all{transition:all .2s ease;}.transition-colors{transition:color .2s,background-color .2s,border-color .2s;}
.object-cover{object-fit:cover;}

/* TEXT COLORS */
.text-deep{color:var(--deep);}.text-darkest{color:var(--darkest);}
.text-ink-dark{color:var(--ink-dark);}.text-ink-mid{color:var(--ink-mid);}.text-ink-faint{color:var(--ink-faint);}
.text-cyan{color:var(--cyan);}.text-coral{color:var(--coral);}.text-yellow{color:var(--yellow);}.text-sand{color:var(--sand);}
.text-mint{color:var(--mint);}.text-forest{color:var(--forest);}.text-rust{color:var(--rust);}
.text-white{color:#fff;}.text-black{color:#000;}
.text-ink-50{color:rgba(13,43,46,.5);}.text-ink-40{color:rgba(13,43,46,.4);}.text-ink-30{color:rgba(13,43,46,.3);}.text-ink-25{color:rgba(13,43,46,.25);}
.text-white-60{color:rgba(255,255,255,.6);}.text-white-40{color:rgba(255,255,255,.4);}.text-white-70{color:rgba(255,255,255,.7);}

/* BG COLORS */
.bg-page{background:var(--page);}.bg-surface{background:var(--surface);}.bg-surface-2{background:var(--surface-2);}
.bg-deep{background:var(--deep);}.bg-darkest{background:var(--darkest);}.bg-forest{background:var(--forest);}.bg-rust{background:var(--rust);}
.bg-cyan{background:var(--cyan);}.bg-coral{background:var(--coral);}.bg-yellow{background:var(--yellow);}.bg-sand{background:var(--sand);}.bg-mint{background:var(--mint);}
.bg-white{background:#fff;}.bg-black{background:#000;}
.bg-deep-05{background:rgba(1,58,64,.05);}.bg-deep-08{background:rgba(1,58,64,.08);}.bg-deep-10{background:rgba(1,58,64,.1);}
.bg-cyan-10{background:rgba(5,242,242,.1);}.bg-coral-10{background:rgba(242,137,114,.1);}.bg-yellow-10{background:rgba(242,190,34,.1);}

/* RESPONSIVE */
@media(min-width:640px){
  .sm-flex-row{flex-direction:row;}.sm-text-left{text-align:left;}.sm-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));}
  .sm-p-8{padding:2rem;}.sm-py-28{padding-top:7rem;padding-bottom:7rem;}
}

/* Project body responsive layout */
#proj-body-grid {
  grid-template-columns: 1fr; /* Mobile: stack vertically */
}

@media (min-width: 768px) {
  #proj-body-grid {
    grid-template-columns: 2fr 1fr; /* Desktop: readable text + sidebar */
    align-items: start;
  }
}

/* Prevent column squeezing (critical for long text) */
#proj-body-grid > div {
  min-width: 0;
}

@media(min-width:768px){
  .md-flex{display:flex;}.md-grid{display:grid;}.md-hidden{display:none;}.md-block{display:block;}
  .md-flex-row{flex-direction:row;}.md-items-center{align-items:center;}.md-justify-between{justify-content:space-between;}.md-justify-end{justify-content:flex-end;}
  .md-text-left{text-align:left;}.md-gap-16{gap:4rem;}.md-self-start{align-self:flex-start;}
  .md-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));}.md-grid-3{grid-template-columns:repeat(3,minmax(0,1fr));}.md-grid-4{grid-template-columns:repeat(4,minmax(0,1fr));}
  .md-grid-about{grid-template-columns:280px 1fr;}.md-grid-contact{grid-template-columns:1fr 1.5fr;}
  .md-w-half{width:50%;}.md-sticky{position:sticky;}.md-top-24{top:6rem;}.md-py-36{padding-top:9rem;padding-bottom:9rem;}
  .md-min-h-88{min-height:22rem;}.md-aspect-auto{aspect-ratio:auto;}.md-max-w-full{max-width:100%;}
}
@media(min-width:1024px){
  .lg-grid-3{grid-template-columns:repeat(3,minmax(0,1fr));}.lg-grid-about{grid-template-columns:320px 1fr;}
}

/* Color palette strip */
.color-stripe{height:4px;background:linear-gradient(90deg,var(--coral),var(--yellow),var(--cyan),var(--mint),var(--teal-b));}

/* Projects grid placeholder images */
.proj-placeholder{
  display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',cursive;font-size:4rem;letter-spacing:.05em;
  height:100%;min-height:200px;
}

/* Number accent */
.num-accent{
  font-family:'Bebas Neue',cursive;font-size:clamp(3rem,7vw,6rem);
  line-height:1;letter-spacing:.04em;
}

/* ── Back link ── */
.back-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-mid);transition:color .2s;}
.back-link:hover{color:var(--deep);}
.arrow-back{display:inline-block;transition:transform .2s;}
.back-link:hover .arrow-back{transform:translateX(-4px);}

/* ── Tag / filter pills ── */
.filter-pill{padding:.4rem 1rem;border-radius:9999px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border:1px solid rgba(1,58,64,.15);color:var(--ink-mid);background:transparent;cursor:pointer;transition:all .2s;}
.filter-pill:hover,.filter-pill.active{border-color:var(--deep);color:var(--deep);background:rgba(1,58,64,.06);}
