/* ============================================================
   WEB ARTISANS — inner page patterns
   ============================================================ */

/* ---------- Page hero ---------- */
.page-hero{ position:relative; padding-top:clamp(140px,18vh,210px); padding-bottom:clamp(48px,6vw,86px); overflow:hidden; }
.page-hero .hero-glow{ position:absolute; inset:0; z-index:0; background:radial-gradient(60% 80% at 88% -10%, var(--brand-soft), transparent 60%); pointer-events:none; }
.page-hero .wrap{ position:relative; z-index:2; }
.page-hero h1{ max-width:16ch; margin:.4em 0 0; }
.page-hero .lead{ margin-top:1.6rem; max-width:54ch; }
.breadcrumb{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--fg-3); display:flex; gap:.6em; align-items:center; }
.breadcrumb a{ color:var(--fg-3); transition:color .25s; }
.breadcrumb a:hover{ color:var(--brand-bright); }

/* ---------- Detailed service blocks ---------- */
.svc-block{ display:grid; grid-template-columns:0.9fr 1.4fr; gap:clamp(32px,6vw,90px); padding-block:clamp(48px,6vw,84px); border-top:1px solid var(--line); align-items:start; }
.svc-block:first-of-type{ border-top:none; }
.svc-block .s-num{ font-family:var(--font-mono); font-size:.78rem; color:var(--brand-bright); letter-spacing:.06em; }
.svc-block h2{ font-family:var(--font-display); font-weight:300; font-size:clamp(1.9rem,3.4vw,2.8rem); letter-spacing:-.02em; margin:1.1rem 0 1.3rem; line-height:1.02; }
.svc-block .s-desc{ color:var(--fg-2); font-size:1.08rem; max-width:50ch; }
.svc-feats{ list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); margin-top:0; }
.svc-feats li{ background:var(--ink); padding:1.4rem 1.5rem; }
.svc-feats li h4{ font-family:var(--font-sans); font-weight:600; font-size:1rem; margin-bottom:.5rem; letter-spacing:0; }
.svc-feats li p{ color:var(--fg-2); font-size:.92rem; }
.svc-stack{ display:flex; flex-wrap:wrap; gap:8px; margin-top:1.8rem; }
.svc-block .svc-media{ aspect-ratio:4/3; margin-top:clamp(20px,2vw,28px); overflow:hidden; border-radius:var(--radius); background:var(--ink-3); }
.svc-block .svc-media .ph{ width:100%; height:100%; transition:transform .8s var(--ease); }
.svc-block:hover .svc-media .ph{ transform:scale(1.05); }
@media (prefers-reduced-motion:reduce){ .svc-block .svc-media .ph{ transition:none; transform:none; } }
@media(max-width:820px){ .svc-block{ grid-template-columns:1fr; gap:24px; } .svc-feats{ grid-template-columns:1fr; } .svc-block .svc-media{ aspect-ratio:16/9; } }

/* ---------- Generic 3-col cards ---------- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2vw,28px); }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,2.4vw,34px); }
@media(max-width:880px){ .grid-3{ grid-template-columns:1fr 1fr; } }
@media(max-width:620px){ .grid-3,.grid-2{ grid-template-columns:1fr; } }

.feature-card{ padding:clamp(26px,2.5vw,38px); height:100%; display:flex; flex-direction:column; }
.feature-card .fc-icon{ width:46px; height:46px; border:1px solid var(--line-2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); color:var(--brand-bright); font-size:.85rem; margin-bottom:1.6rem; }
.feature-card h3{ font-family:var(--font-display); font-weight:400; font-size:1.5rem; letter-spacing:-.01em; margin-bottom:.7rem; line-height:1.08; }
.feature-card p{ color:var(--fg-2); font-size:.98rem; }
.feature-card .more{ margin-top:auto; padding-top:1.6rem; }

/* ---------- Industries ---------- */
.ind-card{ padding:0; overflow:hidden; display:flex; flex-direction:column; }
.ind-card .ic-media{ aspect-ratio:16/10; overflow:hidden; background:var(--ink-3); }
.ind-card .ic-media .ph{ width:100%; height:100%; transition:transform .8s var(--ease); }
.ind-card:hover .ic-media .ph{ transform:scale(1.05); }
.ind-card .ic-body{ padding:clamp(26px,2.5vw,38px); display:flex; flex-direction:column; flex:1; min-height:240px; }
@media (prefers-reduced-motion:reduce){ .ind-card .ic-media .ph{ transition:none; transform:none; } }
.ind-card .ic-top{ display:flex; justify-content:space-between; align-items:baseline; }
.ind-card .ic-num{ font-family:var(--font-mono); font-size:.74rem; color:var(--fg-3); }
.ind-card h3{ font-family:var(--font-display); font-weight:400; font-size:1.7rem; letter-spacing:-.01em; margin:1.4rem 0 .7rem; }
.ind-card p{ color:var(--fg-2); font-size:.96rem; margin-bottom:1.4rem; }
.ind-card .ic-tags{ margin-top:auto; display:flex; flex-wrap:wrap; gap:7px; }

/* ---------- Case studies ---------- */
.case-feature{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(28px,4vw,60px); align-items:center; }
.case-feature .ph{ aspect-ratio:4/3; border-radius:var(--radius); }
.case-list{ display:flex; flex-direction:column; }
.case-row{ display:grid; grid-template-columns:auto auto 1.5fr 1fr auto; gap:30px; align-items:center; padding:clamp(22px,2.6vw,34px) 0; border-top:1px solid var(--line); transition:padding-left .4s var(--ease); }
.case-row:hover{ padding-left:14px; }
.case-row .c-idx{ font-family:var(--font-mono); font-size:.78rem; color:var(--brand-bright); }
.case-row .c-thumb{ width:84px; aspect-ratio:4/3; border-radius:var(--radius-sm); overflow:hidden; background:var(--ink-3); }
.case-row .c-thumb .ph{ width:100%; height:100%; transition:transform .8s var(--ease); }
.case-row:hover .c-thumb .ph{ transform:scale(1.05); }
@media (prefers-reduced-motion:reduce){ .case-row .c-thumb .ph{ transition:none; transform:none; } }
.case-row h3{ font-family:var(--font-display); font-weight:400; font-size:clamp(1.3rem,2vw,1.7rem); letter-spacing:-.01em; }
.case-row .c-sector{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--fg-3); }
.case-row .c-arrow{ color:var(--fg-3); transition:.35s; }
.case-row:hover .c-arrow{ color:var(--brand-bright); transform:translateX(5px); }
@media(max-width:760px){ .case-feature{ grid-template-columns:1fr; } .case-row{ grid-template-columns:auto 1fr; gap:6px 18px; } .case-row .c-sector{ grid-column:2; } .case-row .c-arrow{ display:none; } .case-row .c-thumb{ display:none; } }

/* ---------- About / team ---------- */
.value-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.value-item{ background:var(--ink); padding:clamp(28px,3vw,44px); }
.value-item .v-num{ font-family:var(--font-mono); font-size:.74rem; color:var(--brand-bright); }
.value-item h3{ font-family:var(--font-display); font-weight:400; font-size:1.55rem; margin:1.3rem 0 .7rem; letter-spacing:-.01em; }
.value-item p{ color:var(--fg-2); font-size:.96rem; }
@media(max-width:820px){ .value-list{ grid-template-columns:1fr; } }

.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,2vw,26px); }
.team-card .ph{ aspect-ratio:3/4; border-radius:var(--radius); margin-bottom:1.1rem; }
.team-card h4{ font-family:var(--font-display); font-weight:400; font-size:1.25rem; letter-spacing:-.01em; }
.team-card .role{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--fg-3); margin-top:.4rem; }
@media(max-width:820px){ .team-grid{ grid-template-columns:1fr 1fr; } }

/* Perfiles / roles (sin individuos, por privacidad) */
.role-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,26px); }
.role-card{ display:flex; flex-direction:column; padding:clamp(24px,2.4vw,34px); border:1px solid var(--line); border-radius:var(--radius); background:var(--ink-2); transition:border-color .3s, transform .3s var(--ease); }
.role-card:hover{ border-color:var(--line-2); transform:translateY(-3px); }
.role-card .r-icon{ width:46px; height:46px; border:1px solid var(--line-2); border-radius:12px; display:flex; align-items:center; justify-content:center; color:var(--brand-bright); margin-bottom:1.4rem; }
.role-card .r-icon svg{ width:22px; height:22px; }
.role-card h3{ font-family:var(--font-display); font-weight:400; font-size:1.4rem; letter-spacing:-.01em; line-height:1.1; }
.role-card p{ color:var(--fg-2); font-size:.95rem; margin-top:.6rem; }
@media(max-width:880px){ .role-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .role-grid{ grid-template-columns:1fr; } }

/* ---------- Content image bands (about / careers) ---------- */
.mf-media{ aspect-ratio:16/10; margin-top:clamp(24px,3vw,40px); overflow:hidden; border-radius:var(--radius); background:var(--ink-3); }
.mf-media .ph{ width:100%; height:100%; transition:transform .8s var(--ease); }
.mf-media:hover .ph{ transform:scale(1.05); }
.team-band,.culture-band{ aspect-ratio:21/9; margin-top:clamp(28px,3.5vw,44px); overflow:hidden; border-radius:var(--radius); background:var(--ink-3); }
.culture-band{ margin-bottom:clamp(8px,1vw,12px); }
.team-band .ph,.culture-band .ph{ width:100%; height:100%; transition:transform .8s var(--ease); }
.team-band:hover .ph,.culture-band:hover .ph{ transform:scale(1.05); }
@media (prefers-reduced-motion:reduce){ .mf-media .ph,.team-band .ph,.culture-band .ph{ transition:none; transform:none; } }
@media(max-width:760px){ .team-band,.culture-band{ aspect-ratio:16/9; } }

/* ---------- Blog ---------- */
.featured-post{ display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(28px,4vw,56px); align-items:center; padding-bottom:clamp(40px,5vw,64px); border-bottom:1px solid var(--line); margin-bottom:clamp(40px,5vw,64px); }
.featured-post .ph{ aspect-ratio:16/11; border-radius:var(--radius); }
.featured-post h2{ font-family:var(--font-display); font-weight:300; font-size:clamp(1.9rem,3.4vw,2.9rem); letter-spacing:-.02em; line-height:1.04; margin:1.3rem 0 1.2rem; }
.featured-post p{ color:var(--fg-2); font-size:1.05rem; max-width:48ch; }
.post-meta{ display:flex; gap:1rem; align-items:center; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--fg-3); }
.post-meta .cat{ color:var(--brand-bright); }
.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.6vw,36px); }
.post-card{ display:flex; flex-direction:column; }
.post-card .ph{ aspect-ratio:16/10; border-radius:var(--radius); margin-bottom:1.3rem; }
.post-card h3{ font-family:var(--font-display); font-weight:400; font-size:1.4rem; letter-spacing:-.01em; line-height:1.12; margin:.9rem 0; }
.post-card p{ color:var(--fg-2); font-size:.95rem; }
.post-card:hover .ph{ opacity:.85; }
@media(max-width:880px){ .post-grid{ grid-template-columns:1fr 1fr; } .featured-post{ grid-template-columns:1fr; } }
@media(max-width:600px){ .post-grid{ grid-template-columns:1fr; } }

.cat-filter{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:clamp(28px,3vw,44px); }
.cat-filter button,.cat-filter a{ display:inline-block; font-family:var(--font-mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; padding:.6em 1.1em; border:1px solid var(--line-2); border-radius:40px; color:var(--fg-2); transition:.3s; cursor:pointer; }
.cat-filter button.on,.cat-filter button:hover,.cat-filter a.on,.cat-filter a:hover{ background:var(--fg); color:#fff; border-color:var(--fg); text-decoration:none; }

/* ---------- Blog: barra de filtros ---------- */
.blog-filters{ display:flex; gap:12px; flex-wrap:wrap; align-items:flex-end; margin-bottom:clamp(20px,2.4vw,30px); }
.blog-filters .bf-search{ flex:1; min-width:220px; }
.blog-filters input[type="search"]{ width:100%; background:var(--ink-1); border:1px solid var(--line-2); border-radius:980px; padding:.8rem 1.2rem; font-family:var(--font-sans); font-size:1rem; color:var(--fg); transition:border-color .3s; }
.blog-filters input[type="search"]:focus{ outline:none; border-color:var(--brand-bright); }
.blog-filters .bf-date{ display:flex; flex-direction:column; gap:.4rem; font-family:var(--font-mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--fg-3); }
.blog-filters .bf-date input{ background:var(--ink-1); border:1px solid var(--line-2); border-radius:12px; padding:.62rem .8rem; font-family:var(--font-sans); font-size:.92rem; color:var(--fg); }
.blog-filters .bf-date input:focus{ outline:none; border-color:var(--brand-bright); }
.blog-filters .bf-clear{ align-self:center; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--fg-3); }
.blog-filters .bf-clear:hover{ color:var(--brand-bright); }
@media(max-width:600px){ .blog-filters{ gap:10px; } .blog-filters .bf-date{ flex:1; } }

/* ---------- Blog: paginador ---------- */
.blog-pager{ display:flex; gap:8px; flex-wrap:wrap; justify-content:center; align-items:center; margin-top:clamp(40px,5vw,64px); }
.blog-pager a{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:.04em; min-width:42px; text-align:center; padding:.62em .9em; border:1px solid var(--line-2); border-radius:40px; color:var(--fg-2); transition:.25s; }
.blog-pager a:hover{ border-color:var(--fg); color:var(--fg); text-decoration:none; }
.blog-pager a.on{ background:var(--brand); color:#fff; border-color:var(--brand); }
.blog-pager .bp-arrow{ display:inline-flex; align-items:center; gap:.5em; text-transform:uppercase; font-size:.72rem; }
.blog-pager .bp-arrow .arr{ font-size:.95rem; }

/* ---------- Blog: estado vacío ---------- */
.blog-empty{ text-align:center; max-width:520px; margin:clamp(40px,6vw,80px) auto; }
.blog-empty h3{ font-family:var(--font-display); font-weight:400; font-size:clamp(1.5rem,2.6vw,2.1rem); letter-spacing:-.02em; }

/* ---------- Page hero oscuro (secciones interiores como el home) ---------- */
.page-hero.is-dark{
  --line:rgba(255,255,255,.12); --line-2:rgba(255,255,255,.22);
  --fg:#f5f5f7; --fg-2:rgba(245,245,247,.70); --fg-3:rgba(245,245,247,.48);
  --brand-bright:#6a8bff; --brand-soft:rgba(106,139,255,.14);
  background:#06070d; color:var(--fg);
  padding-bottom:clamp(56px,7vw,104px);
}
.page-hero.is-dark .scrim{ background:linear-gradient(180deg, rgba(6,7,13,.72) 0%, rgba(6,7,13,.30) 42%, rgba(6,7,13,.86) 100%); }

/* ---------- /carreras: job-row como botón + modal de postulación ---------- */
button.job-row{ width:100%; background:none; border:0; font:inherit; color:inherit; cursor:pointer; text-align:left; }

/* El oscurecido + blur va sobre el propio .modal (contenedor scrollable a pantalla completa),
   no en un backdrop position:fixed aparte: así la rueda/touch scrollea el modal desde CUALQUIER
   punto del viewport, no solo sobre el card. */
.modal{ position:fixed; inset:0; z-index:300; display:none; overflow-y:auto; -webkit-overflow-scrolling:touch; overscroll-behavior:contain; background:rgba(6,7,13,.55); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); }
.modal.open{ display:flex; align-items:flex-start; justify-content:center; padding:clamp(16px,6vh,64px) 16px; }
.modal-card{ position:relative; z-index:1; width:100%; max-width:620px; margin:0; background:var(--bg); color:var(--fg); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(26px,4vw,44px); box-shadow:0 40px 100px -20px rgba(0,0,0,.5); }
.modal-x{ position:absolute; top:12px; right:16px; background:none; border:0; font-size:1.9rem; line-height:1; color:var(--fg-3); cursor:pointer; }
.modal-x:hover{ color:var(--fg); }
.modal-head{ margin-bottom:1.6rem; }
.modal-title{ font-family:var(--font-display); font-weight:400; font-size:clamp(1.5rem,3vw,2rem); letter-spacing:-.02em; line-height:1.1; }
.modal-meta{ font-family:var(--font-mono); font-size:.76rem; letter-spacing:.06em; text-transform:uppercase; color:var(--fg-3); margin-top:.6rem; }
.modal-desc{ color:var(--fg-2); font-size:.98rem; line-height:1.6; margin-top:1rem; white-space:pre-line; max-height:30vh; overflow-y:auto; }
.modal .form-success{ margin-top:0; }
.page-hero.is-dark h1.display,.page-hero.is-dark .breadcrumb a:hover{ color:#fff; }

/* ---------- Article / prose ---------- */
.article-wrap{ max-width:760px; margin-inline:auto; }
.article-hero .ph{ aspect-ratio:21/9; border-radius:var(--radius); margin-top:clamp(28px,4vw,48px); }
.prose{ font-size:1.2rem; line-height:1.72; color:var(--fg-2); letter-spacing:-.01em; }
.prose > * + *{ margin-top:1.5em; }
.prose h2{ font-weight:600; font-size:clamp(1.7rem,2.8vw,2.3rem); letter-spacing:-.025em; color:var(--fg); margin-top:2.2em; line-height:1.1; }
.prose h3{ font-weight:600; font-size:1.5rem; color:var(--fg); margin-top:1.8em; letter-spacing:-.02em; }
.prose p{ color:var(--fg-2); }
.prose a{ color:var(--brand); text-decoration:underline; text-underline-offset:3px; }
.prose blockquote{ border-left:3px solid var(--brand); padding-left:1.4em; font-weight:600; font-size:1.55rem; line-height:1.3; color:var(--fg); letter-spacing:-.025em; margin-block:1.6em; }
.prose ul,.prose ol{ padding-left:1.3em; color:var(--fg-2); }
.prose li + li{ margin-top:.6em; }
.prose strong{ color:var(--fg); font-weight:600; }
.prose code{ font-family:var(--font-code); font-size:.84em; background:var(--ink-1); padding:.15em .45em; border-radius:6px; color:var(--brand); }
.author-row{ display:flex; align-items:center; gap:1rem; margin-top:clamp(40px,5vw,64px); padding-top:1.8rem; border-top:1px solid var(--line); }
.author-row .ph{ width:54px; height:54px; border-radius:50%; flex-shrink:0; }
.author-row .a-name{ font-family:var(--font-display); font-size:1.2rem; }
.author-row .a-role{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--fg-3); margin-top:.3rem; }

/* ---------- Careers ---------- */
.job-list{ border-top:1px solid var(--line); }
.job-row{ display:grid; grid-template-columns:1.6fr 1fr 1fr auto; gap:24px; align-items:center; padding:clamp(22px,2.6vw,32px) 0; border-bottom:1px solid var(--line); transition:padding-left .4s var(--ease); }
.job-row:hover{ padding-left:14px; }
.job-row h3{ font-family:var(--font-display); font-weight:400; font-size:clamp(1.3rem,2vw,1.6rem); letter-spacing:-.01em; }
.job-row .j-meta{ font-family:var(--font-mono); font-size:.76rem; letter-spacing:.05em; color:var(--fg-3); text-transform:uppercase; }
.job-row .j-arrow{ color:var(--fg-3); transition:.35s; }
.job-row:hover .j-arrow{ color:var(--brand-bright); transform:translateX(5px); }
@media(max-width:760px){ .job-row{ grid-template-columns:1fr auto; gap:6px 16px; } .job-row .j-meta{ grid-column:1; } }

.perk-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.perk{ background:#fff; padding:clamp(24px,2.6vw,36px); }
.perk h4{ font-family:var(--font-display); font-weight:400; font-size:1.3rem; margin-bottom:.5rem; }
.perk p{ color:var(--paper-ink-2); font-size:.95rem; }
@media(max-width:760px){ .perk-list{ grid-template-columns:1fr; } }

/* ---------- Contact form ---------- */
.contact-grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(40px,6vw,90px); align-items:start; }
.form-field{ margin-bottom:1.5rem; }
.form-field label{ display:block; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--fg-3); margin-bottom:.7rem; }
.form-field input,.form-field textarea,.form-field select{
  width:100%; background:var(--ink-2); border:1px solid var(--line-2); border-radius:var(--radius);
  padding:.95rem 1.1rem; color:var(--fg); font-family:var(--font-sans); font-size:1rem; transition:border-color .3s, background .3s;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{ outline:none; border-color:var(--brand-bright); background:var(--ink-3); }
.form-field textarea{ resize:vertical; min-height:130px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.form-note{ font-size:.84rem; color:var(--fg-3); margin-top:1rem; }
.contact-aside .ca-block{ padding-bottom:1.8rem; margin-bottom:1.8rem; border-bottom:1px solid var(--line); }
.contact-aside h4{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--fg-3); margin-bottom:.9rem; }
.contact-aside .big-link{ font-family:var(--font-display); font-weight:300; font-size:clamp(1.3rem,2.2vw,1.7rem); letter-spacing:-.01em; }
.contact-aside .big-link:hover{ color:var(--brand-bright); }
@media(max-width:820px){ .contact-grid{ grid-template-columns:1fr; } .form-row{ grid-template-columns:1fr; } }

/* form success */
.form-success{ display:none; padding:2rem; border:1px solid var(--brand); border-radius:var(--radius); background:var(--brand-soft); }
.form-success.show{ display:block; }
