:root{
  --bg:#0f1117; --bg2:#151924; --panel:#fff; --ink:#111827; --muted:#5b6472; --line:#e6e9ef;
  --accent:#00a7a5; --accent2:#f4b942; --accent3:#7657ff; --white:#fff;
  --radius:24px; --shadow:0 18px 60px rgba(15,17,23,.14); --max:1180px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:"Inter Tight",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:#fbfbf8;line-height:1.6}a{color:inherit}.skip-link{position:absolute;left:-999px;top:auto}.skip-link:focus{left:16px;top:16px;background:#fff;color:#111;padding:10px 14px;z-index:9999;border-radius:10px}.container{width:min(var(--max),calc(100% - 32px));margin:auto}.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-bottom:1px solid rgba(0,0,0,.06)}.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:800;letter-spacing:-.03em}.brand-mark{width:54px;height:54px;border-radius:0!important;object-fit:contain;background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.08);padding:2px}.brand span{font-size:1.05rem}.menu{display:flex;align-items:center;gap:20px}.menu a{text-decoration:none;font-weight:700;font-size:.95rem}.menu a:hover,.menu a:focus{color:var(--accent)}.nav-cta{background:var(--ink);color:#fff!important;padding:10px 16px;border-radius:999px}.nav-toggle{display:none;border:0;background:#111;color:#fff;border-radius:12px;padding:10px 12px}.hero{position:relative;overflow:hidden;background:radial-gradient(circle at 15% 10%,rgba(0,167,165,.28),transparent 34%),radial-gradient(circle at 90% 20%,rgba(244,185,66,.34),transparent 28%),linear-gradient(135deg,#10131c,#202637 70%,#16191f);color:#fff}.hero-grid{min-height:calc(100vh - 78px);display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center;padding:84px 0}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:#9ef4ef}.hero h1{font-size:clamp(3.1rem,8vw,7.8rem);line-height:.88;margin:20px 0;letter-spacing:-.08em}.hero p{font-size:clamp(1.08rem,1.8vw,1.35rem);max-width:720px;color:#e7edf5}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:14px 22px;text-decoration:none;font-weight:800;border:2px solid transparent}.btn-primary{background:var(--accent);color:#042626}.btn-secondary{border-color:rgba(255,255,255,.32);color:#fff}.hero-card{position:relative;border-radius:34px;overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.35);transform:rotate(1.5deg)}.hero-card img{width:100%;height:560px;object-fit:cover;display:block}.hero-card:after{content:"Design · 3D · Digital";position:absolute;left:24px;bottom:24px;background:rgba(255,255,255,.88);color:#111;padding:12px 16px;border-radius:999px;font-weight:900}.section{padding:92px 0}.section-dark{background:var(--bg);color:#fff}.section-kicker{font-weight:900;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-size:.82rem;margin-bottom:12px}.section h2{font-size:clamp(2.1rem,5vw,4.4rem);line-height:1;margin:0 0 24px;letter-spacing:-.06em}.lead{font-size:1.18rem;color:var(--muted);max-width:850px}.section-dark .lead{color:#cbd5e1}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:0 10px 40px rgba(0,0,0,.05)}.card h3{margin:0 0 10px;font-size:1.25rem}.card p{color:var(--muted);margin:0}.service-card{background:linear-gradient(180deg,#fff,#fbfaf5)}.process{counter-reset:item}.process .card{position:relative;padding-left:72px}.process .card:before{counter-increment:item;content:counter(item);position:absolute;left:24px;top:28px;width:34px;height:34px;border-radius:50%;background:var(--accent2);display:grid;place-items:center;font-weight:900}.gallery{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:18px;margin-top:34px}.gallery img{width:100%;height:360px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}.gallery img:nth-child(2){height:460px}.pill-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.pill{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);border-radius:999px;padding:10px 14px;font-weight:800}.contact-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:start}.contact-box{background:#fff;border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}label{display:block;font-weight:800;margin:14px 0 6px}input,textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:14px 16px;font:inherit;background:#fff}textarea{min-height:150px}.check{display:flex;gap:10px;align-items:flex-start;margin-top:16px;color:var(--muted)}.check input{width:auto;margin-top:6px}.form-note{font-size:.93rem;color:var(--muted)}.site-footer{background:#080a10;color:#fff;padding:42px 0 0}.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:24px;padding-bottom:32px}.footer-grid a{display:block;color:#dbe3ee;text-decoration:none;margin:8px 0}.footer-grid a:hover{color:#fff}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;color:#a9b3c5;font-size:.92rem}.legal-main{padding:120px 0 70px}.legal-main h1{font-size:clamp(2.6rem,6vw,5.4rem);line-height:1;letter-spacing:-.06em}.legal-main article{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:34px}.kd{background:#fff;padding:16px;text-align:center}.kd img{max-width:100%;height:auto}.small{font-size:.92rem;color:#6b7280}.success{display:none;background:#e8fff8;color:#064e3b;border:1px solid #99f6e4;border-radius:14px;padding:14px;margin-top:16px}.success.show{display:block}@media(max-width:920px){.nav-toggle{display:inline-flex}.menu{position:absolute;left:16px;right:16px;top:78px;display:none;flex-direction:column;align-items:flex-start;background:#fff;border-radius:20px;padding:18px;box-shadow:var(--shadow)}.menu.open{display:flex}.hero-grid,.grid-2,.contact-wrap,.footer-grid{grid-template-columns:1fr}.hero-card img{height:380px}.cards{grid-template-columns:1fr}.gallery{grid-template-columns:1fr}.gallery img,.gallery img:nth-child(2){height:280px}.section{padding:64px 0}}@media(max-width:560px){.brand span{display:none}.hero-grid{padding:56px 0}.hero h1{font-size:3.8rem}.nav{height:70px}.menu{top:70px}.contact-box{padding:22px}.section h2{font-size:2.35rem}}

/* VR page */
.menu a[aria-current="page"]{color:var(--accent)}
.vr-hero{background:radial-gradient(circle at 15% 15%,rgba(0,167,165,.36),transparent 32%),radial-gradient(circle at 85% 18%,rgba(118,87,255,.32),transparent 30%),linear-gradient(135deg,#07131f,#16243b 62%,#0b151e)}
.vr-teaser{background:linear-gradient(135deg,#eefdfa,#fff8e6)}
.check-list{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:28px}
.check-list p{margin:0 0 14px;color:#dbeafe}.check-list p:last-child{margin-bottom:0}.check-list strong{color:#fff}
.resource-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}.resource-group{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:0 10px 40px rgba(0,0,0,.05)}.resource-group h3{margin:0 0 14px;font-size:1.22rem}.resource-group ul{list-style:none;margin:0;padding:0}.resource-group li{border-top:1px solid var(--line)}.resource-group li:first-child{border-top:0}.resource-group a{display:flex;justify-content:space-between;gap:12px;padding:10px 0;text-decoration:none;font-weight:750;color:#172033}.resource-group a::after{content:"↗";color:var(--accent);font-weight:900}.resource-group a:hover,.resource-group a:focus{color:var(--accent)}
@media(max-width:920px){.resource-grid{grid-template-columns:1fr}.vr-hero .hero-card img{height:340px}}


/* =========================================================
   ACCESSIBILITAT TIPOGRÀFICA I LLEGIBILITAT
   S'evita que els titulars quedin massa compactes.
   ========================================================= */
body{
  font-family:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif !important;
  font-size:17px;
  line-height:1.72 !important;
  letter-spacing:0.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.hero h1,
.section h2,
.legal-main h1,
h1,h2{
  letter-spacing:-0.025em !important;
  line-height:1.08 !important;
  word-spacing:0.02em;
  text-wrap:balance;
}
.hero h1{
  font-size:clamp(3rem, 6.8vw, 6.7rem) !important;
  max-width:1050px;
}
.section h2{
  font-size:clamp(2.05rem, 4.4vw, 4.05rem) !important;
}
p,.lead,.card p,.resource-group a,.menu a{
  line-height:1.68 !important;
}
.lead{
  font-size:clamp(1.08rem, 1.45vw, 1.22rem) !important;
}
.card h3,.resource-group h3{
  line-height:1.25 !important;
  letter-spacing:-0.01em !important;
}
:focus-visible{
  outline:3px solid var(--accent2) !important;
  outline-offset:4px;
  border-radius:8px;
}
@media(max-width:560px){
  body{font-size:16px;}
  .hero h1{font-size:clamp(2.65rem, 14vw, 4rem) !important; line-height:1.1 !important;}
  .section h2{font-size:clamp(2rem, 10vw, 2.6rem) !important;}
}

/* Accés discret al mode editor */
.editor-access-o{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:20px;
  height:20px;
  margin:10px auto 0;
  color:rgba(255,255,255,.42);
  text-decoration:none;
  font-weight:700;
  font-size:.85rem;
  border-radius:999px;
}
.editor-access-o:hover,
.editor-access-o:focus{
  color:#fff;
  background:rgba(255,255,255,.12);
}

/* Editor visual */
.editor-mode [data-auto-editable],
.editor-mode [data-auto-editable-img]{
  outline:2px dashed rgba(0,167,165,.75);
  outline-offset:4px;
  cursor:text;
}
.editor-mode [data-auto-editable-img]{cursor:pointer;}
.editor-bar{
  position:fixed;
  left:16px;
  right:16px;
  bottom:16px;
  z-index:99999;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  background:#0f1117;
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 18px 60px rgba(0,0,0,.35);
  border-radius:18px;
  padding:12px 14px;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
.editor-bar button,
.editor-bar a{
  border:0;
  border-radius:999px;
  padding:9px 13px;
  background:#00a7a5;
  color:#042626;
  font-weight:800;
  text-decoration:none;
  cursor:pointer;
}
.editor-bar .danger{background:#f4b942;color:#111827;}
@media(max-width:650px){.editor-bar{flex-direction:column;align-items:flex-start}.editor-bar span{display:flex;flex-wrap:wrap;gap:8px}}

/* Formulari i missatges accessibles */
.success[data-error="true"]{background:#fee2e2;color:#7f1d1d;border-color:#fecaca;}
button[aria-busy="true"]{opacity:.65;cursor:progress;}

/* Logo VG i fotografia personal */
.brand-mark[src*="logo-vg"]{border-radius:0!important;object-fit:contain;background:#fff;padding:2px;}
.hero-card img[src*="foto-valenti-garcia"]{object-position:center center;}
@media(max-width:920px){.hero-card img[src*="foto-valenti-garcia"]{height:420px;object-position:center top;}}


/* RA page */
.ra-hero{background:radial-gradient(circle at 18% 14%,rgba(244,185,66,.34),transparent 32%),radial-gradient(circle at 88% 18%,rgba(0,167,165,.32),transparent 30%),linear-gradient(135deg,#111827,#203042 62%,#0f172a)}
.ar-bridge{background:linear-gradient(135deg,#f0fdfa,#fff7ed)}
.dark-text{color:#042626!important}
.ra-types .card{min-height:190px}
@media(max-width:920px){.ra-hero .hero-card img{height:340px}}
